package merlin-lib
Merlin's libraries
Install
Dune Dependency
Authors
Maintainers
Sources
merlin-5.3-502.tbz
sha256=2cea46f12397fa6e31ef0c0d4f5e11c1cfd916ee49420694005c95ebb3aa24bc
sha512=e94abb9ae38149245337db033e2c3891c7ec772168e99abf1bda0216a894c0854e7170b56fe88eba83ec98f2ebc0f5c7c723e8db14f59eeb6dd348bec12c6d62
doc/src/merlin-lib.ocaml_merlin_specific/browse_raw.ml.html
Source file browse_raw.ml
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582 583 584 585 586 587 588 589 590 591 592 593 594 595 596 597 598 599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662 663 664 665 666 667 668 669 670 671 672 673 674 675 676 677 678 679 680 681 682 683 684 685 686 687 688 689 690 691 692 693 694 695 696 697 698 699 700 701 702 703 704 705 706 707 708 709 710 711 712 713 714 715 716 717 718 719 720 721 722 723 724 725 726 727 728 729 730 731 732 733 734 735 736 737 738 739 740 741 742 743 744 745 746 747 748 749 750 751 752 753 754 755 756 757 758 759 760 761 762 763 764 765 766 767 768 769 770 771 772 773 774 775 776 777 778 779 780 781 782 783 784 785 786 787 788 789 790 791 792 793 794 795 796 797 798 799 800 801 802 803 804 805 806 807 808 809 810 811 812 813 814 815 816 817 818 819 820 821 822 823 824 825 826 827 828 829 830 831 832 833 834 835 836 837 838 839 840 841 842 843 844 845 846 847 848 849 850 851 852 853 854 855 856 857 858 859 860 861 862 863 864 865 866 867 868 869 870 871 872 873 874 875 876 877 878 879 880 881 882 883 884 885 886 887 888 889 890 891 892 893 894 895 896 897 898 899 900 901 902 903 904 905 906 907 908 909 910 911 912 913 914 915 916 917 918 919 920 921 922 923 924 925 926 927 928 929 930
(* {{{ Copying *( This file is part of Merlin, an helper for ocaml editors Copyright (C) 2013 - 2017 Frédéric Bour <frederic.bour(_)lakaban.net> Thomas Refis <refis.thomas(_)gmail.com> Simon Castellan <simon.castellan(_)iuwt.fr> Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. The Software is provided "as is", without warranty of any kind, express or implied, including but not limited to the warranties of merchantability, fitness for a particular purpose and noninfringement. In no event shall the authors or copyright holders be liable for any claim, damages or other liability, whether in an action of contract, tort or otherwise, arising from, out of or in connection with the software or the use or other dealings in the Software. )* }}} *) [@@@ocaml.warning "-9"] open Std type constructor_declaration = Typedtree.constructor_declaration open Typedtree type node = | Dummy | Pattern : _ general_pattern -> node | Expression of expression | Case : _ case -> node | Class_expr of class_expr | Class_structure of class_structure | Class_field of class_field | Class_field_kind of class_field_kind | Module_expr of module_expr | Module_type_constraint of module_type_constraint | Structure of structure | Signature of signature | Structure_item of structure_item * Env.t | Signature_item of signature_item * Env.t | Module_binding of module_binding | Value_binding of value_binding | Module_type of module_type | Module_declaration of module_declaration | Module_type_declaration of module_type_declaration | With_constraint of with_constraint | Core_type of core_type | Package_type of package_type | Row_field of row_field | Value_description of value_description | Type_declaration of type_declaration | Type_kind of type_kind | Type_extension of type_extension | Extension_constructor of extension_constructor | Label_declaration of label_declaration | Constructor_declaration of constructor_declaration | Class_type of class_type | Class_signature of class_signature | Class_type_field of class_type_field | Class_declaration of class_declaration | Class_description of class_description | Class_type_declaration of class_type_declaration | Binding_op of binding_op | Include_description of include_description | Include_declaration of include_declaration | Open_description of open_description | Open_declaration of open_declaration | Method_call of expression * meth * Location.t | Record_field of [ `Expression of expression | `Pattern of pattern ] * Types.label_description * Longident.t Location.loc | Module_binding_name of module_binding | Module_declaration_name of module_declaration | Module_type_declaration_name of module_type_declaration let node_update_env env0 = function | Pattern { pat_env = env } | Expression { exp_env = env } | Class_expr { cl_env = env } | Method_call ({ exp_env = env }, _, _) | Record_field (`Expression { exp_env = env }, _, _) | Record_field (`Pattern { pat_env = env }, _, _) | Module_expr { mod_env = env } | Module_type { mty_env = env } | Structure_item (_, env) | Signature_item (_, env) | Core_type { ctyp_env = env } | Class_type { cltyp_env = env } -> env | Dummy | Case _ | Class_structure _ | Class_signature _ | Class_field _ | Class_field_kind _ | Type_extension _ | Extension_constructor _ | Package_type _ | Row_field _ | Type_declaration _ | Type_kind _ | Module_binding _ | Module_declaration _ | Module_binding_name _ | Module_declaration_name _ | Module_type_declaration _ | Module_type_constraint _ | Module_type_declaration_name _ | With_constraint _ | Structure _ | Signature _ | Value_description _ | Value_binding _ | Constructor_declaration _ | Label_declaration _ | Class_declaration _ | Class_description _ | Class_type_declaration _ | Class_type_field _ | Include_description _ | Include_declaration _ | Open_description _ | Open_declaration _ | Binding_op _ -> env0 let node_real_loc loc0 = function | Expression { exp_loc = loc } | Pattern { pat_loc = loc } | Method_call (_, _, loc) | Record_field (_, _, { loc }) | Class_expr { cl_loc = loc } | Module_expr { mod_loc = loc } | Structure_item ({ str_loc = loc }, _) | Signature_item ({ sig_loc = loc }, _) | Module_type { mty_loc = loc } | Core_type { ctyp_loc = loc } | Class_type { cltyp_loc = loc } | Class_field { cf_loc = loc } | Module_binding { mb_loc = loc } | Module_declaration { md_loc = loc } | Module_type_declaration { mtd_loc = loc } | Value_description { val_loc = loc } | Value_binding { vb_loc = loc } | Type_declaration { typ_loc = loc } | Label_declaration { ld_loc = loc } | Constructor_declaration { cd_loc = loc } | Class_type_field { ctf_loc = loc } | Class_declaration { ci_loc = loc } | Class_description { ci_loc = loc } | Class_type_declaration { ci_loc = loc } | Extension_constructor { ext_loc = loc } | Include_description { incl_loc = loc } | Include_declaration { incl_loc = loc } | Open_description { open_loc = loc } | Open_declaration { open_loc = loc } | Binding_op { bop_op_name = { loc } } -> loc | Module_type_declaration_name { mtd_name = loc } -> loc.Location.loc | Module_declaration_name { md_name = loc } | Module_binding_name { mb_name = loc } -> loc.Location.loc | Structure _ | Signature _ | Case _ | Class_structure _ | Type_extension _ | Class_field_kind _ | Module_type_constraint _ | With_constraint _ | Row_field _ | Type_kind _ | Class_signature _ | Package_type _ | Dummy -> loc0 let node_attributes = function | Expression exp -> exp.exp_attributes | Pattern pat -> pat.pat_attributes | Class_expr cl -> cl.cl_attributes | Class_field cf -> cf.cf_attributes | Module_expr me -> me.mod_attributes | Structure_item ({ str_desc = Tstr_eval (_, attr) }, _) -> attr | Structure_item ({ str_desc = Tstr_attribute a }, _) -> [ a ] | Signature_item ({ sig_desc = Tsig_attribute a }, _) -> [ a ] | Module_binding mb -> mb.mb_attributes | Value_binding vb -> vb.vb_attributes | Module_type mt -> mt.mty_attributes | Module_declaration md -> md.md_attributes | Module_type_declaration mtd -> mtd.mtd_attributes | Open_description o -> o.open_attributes | Include_declaration i -> i.incl_attributes | Include_description i -> i.incl_attributes | Core_type ct -> ct.ctyp_attributes | Row_field rf -> rf.rf_attributes | Value_description vd -> vd.val_attributes | Type_declaration td -> td.typ_attributes | Label_declaration ld -> ld.ld_attributes | Constructor_declaration cd -> cd.cd_attributes | Type_extension te -> te.tyext_attributes | Extension_constructor ec -> ec.ext_attributes | Class_type ct -> ct.cltyp_attributes | Class_type_field ctf -> ctf.ctf_attributes | Class_declaration ci -> ci.ci_attributes | Class_description ci -> ci.ci_attributes | Class_type_declaration ci -> ci.ci_attributes | Method_call (obj, _, _) -> obj.exp_attributes | Record_field (`Expression obj, _, _) -> obj.exp_attributes | Record_field (`Pattern obj, _, _) -> obj.pat_attributes | _ -> [] let has_attr ~name node = let attrs = node_attributes node in List.exists ~f:(fun a -> let str, _ = Ast_helper.Attr.as_tuple a in str.Location.txt = name) attrs let node_merlin_loc loc0 node = let attributes = node_attributes node in let loc = let open Parsetree in let pred { attr_name = loc; _ } = Location_aux.is_relaxed_location loc in match List.find attributes ~f:pred with | { attr_name; _ } -> attr_name.Location.loc | exception Not_found -> node_real_loc loc0 node in let loc = match node with | Expression { exp_extra; _ } -> List.fold_left ~f:(fun loc0 (_, loc, _) -> Location_aux.union loc0 loc) ~init:loc exp_extra | Pattern { pat_extra; _ } -> List.fold_left ~f:(fun loc0 (_, loc, _) -> Location_aux.union loc0 loc) ~init:loc pat_extra | _ -> loc in loc let app node env f acc = f (node_update_env env node) node acc type 'a f0 = Env.t -> node -> 'a -> 'a type ('b, 'a) f1 = 'b -> Env.t -> 'a f0 -> 'a -> 'a let id_fold _env (_f : _ f0) acc = acc let ( ** ) f1 f2 env (f : _ f0) acc = f2 env f (f1 env f acc) let rec list_fold (f' : _ f1) xs env f acc = match xs with | x :: xs -> list_fold f' xs env f (f' x env f acc) | [] -> acc let array_fold (f' : _ f1) arr env f acc = let acc = ref acc in for i = 0 to Array.length arr - 1 do acc := f' arr.(i) env f !acc done; !acc let rec list_fold_with_next (f' : _ -> _ f1) xs env f acc = match xs with | x :: (y :: _ as xs) -> list_fold_with_next f' xs env f (f' (Some y) x env f acc) | [ x ] -> f' None x env f acc | [] -> acc let option_fold f' o env (f : _ f0) acc = match o with | None -> acc | Some x -> f' x env f acc let of_core_type ct = app (Core_type ct) let of_exp_extra (exp, _, _) = match exp with | Texp_constraint ct -> of_core_type ct | Texp_coerce (cto, ct) -> of_core_type ct ** option_fold of_core_type cto | Texp_poly cto -> option_fold of_core_type cto | Texp_newtype' _ | Texp_newtype _ -> id_fold let of_expression e = app (Expression e) ** list_fold of_exp_extra e.exp_extra let of_pat_extra (pat, _, _) = match pat with | Tpat_constraint ct -> of_core_type ct | Tpat_type _ | Tpat_unpack | Tpat_open _ -> id_fold let of_pattern (type k) (p : k general_pattern) = app (Pattern p) ** list_fold of_pat_extra p.pat_extra let of_case c = app (Case c) let of_label_declaration ct = app (Label_declaration ct) let of_value_binding vb = app (Value_binding vb) let of_module_type mt = app (Module_type mt) let of_module_expr me = app (Module_expr me) let of_typ_param (ct, _) = of_core_type ct let of_constructor_arguments = function | Cstr_tuple cts -> list_fold of_core_type cts | Cstr_record lbls -> list_fold of_label_declaration lbls let of_bop ({ bop_exp; _ } as bop) = app (Binding_op bop) ** of_expression bop_exp let of_record_field obj loc lbl env (f : _ f0) acc = app (Record_field (obj, lbl, loc)) env f acc let of_exp_record_field obj lid_loc lbl = of_record_field (`Expression obj) lid_loc lbl let of_pat_record_field obj loc lbl = of_record_field (`Pattern obj) loc lbl let of_pattern_desc (type k) (desc : k pattern_desc) = match desc with | Tpat_any | Tpat_var _ | Tpat_constant _ | Tpat_variant (_, None, _) -> id_fold | Tpat_alias (p, _, _, _) | Tpat_variant (_, Some p, _) | Tpat_lazy p | Tpat_exception p -> of_pattern p | Tpat_value p -> of_pattern (p :> value general_pattern) | Tpat_tuple ps | Tpat_construct (_, _, ps, None) | Tpat_array ps -> list_fold of_pattern ps | Tpat_construct (_, _, ps, Some (_, ct)) -> list_fold of_pattern ps ** of_core_type ct | Tpat_record (ls, _) -> list_fold (fun (lid_loc, desc, p) -> of_pat_record_field p lid_loc desc ** of_pattern p) ls | Tpat_or (p1, p2, _) -> of_pattern p1 ** of_pattern p2 let of_method_call obj meth loc env (f : _ f0) acc = let loc_start = obj.exp_loc.Location.loc_end in let loc_end = loc.Location.loc_end in let loc = { loc with Location.loc_start; loc_end } in app (Method_call (obj, meth, loc)) env f acc let rec of_expression_desc loc = function | Texp_ident _ | Texp_constant _ | Texp_instvar _ | Texp_variant (_, None) | Texp_new _ | Texp_hole -> id_fold | Texp_let (_, vbs, e) -> of_expression e ** list_fold of_value_binding vbs | Texp_function (params, body) -> list_fold of_function_param params ** of_function_body body | Texp_apply (e, ls) -> of_expression e ** list_fold (function | _, None -> id_fold | _, Some e -> of_expression e) ls | Texp_match (e, cs, _) -> of_expression e ** list_fold of_case cs | Texp_try (e, cs) -> of_expression e ** list_fold of_case cs | Texp_tuple es | Texp_construct (_, _, es) | Texp_array es -> list_fold of_expression es | Texp_variant (_, Some e) | Texp_assert (e, _) | Texp_lazy e | Texp_setinstvar (_, _, _, e) -> of_expression e | Texp_record { fields; extended_expression } -> option_fold of_expression extended_expression ** let fold_field = function | _, Typedtree.Kept _ -> id_fold | desc, Typedtree.Overridden (lid_loc, e) -> of_exp_record_field e lid_loc desc ** of_expression e in array_fold fold_field fields | Texp_field (e, lid_loc, lbl) -> of_expression e ** of_exp_record_field e lid_loc lbl | Texp_setfield (e1, lid_loc, lbl, e2) -> of_expression e1 ** of_expression e2 ** of_exp_record_field e1 lid_loc lbl | Texp_ifthenelse (e1, e2, None) | Texp_sequence (e1, e2) | Texp_while (e1, e2) -> of_expression e1 ** of_expression e2 | Texp_ifthenelse (e1, e2, Some e3) | Texp_for (_, _, e1, e2, _, e3) -> of_expression e1 ** of_expression e2 ** of_expression e3 | Texp_send (e, meth) -> of_expression e ** of_method_call e meth loc (* TODO ulysse CHECK*) | Texp_override (_, ls) -> list_fold (fun (_, _, e) -> of_expression e) ls | Texp_letmodule (mb_id, mb_name, mb_presence, mb_expr, e) -> let mb = { mb_id; mb_name; mb_expr; mb_loc = Location.none; mb_attributes = []; mb_presence; mb_uid = Shape.Uid.internal_not_actually_unique } in app (Module_binding mb) ** of_expression e | Texp_letexception (ec, e) -> app (Extension_constructor ec) ** of_expression e | Texp_object (cs, _) -> app (Class_structure cs) | Texp_pack me -> of_module_expr me | Texp_unreachable | Texp_extension_constructor _ -> id_fold | Texp_letop { let_; ands; body; _ } -> (* let+ ..pat1 and pat2 and ... are represented as pattern couples: [pat1; [pat2; ...]]. The following function flattens these couples. Keeping track of the known size of the tuple prevent wrongly flattening the patterns patN when they are tuples themselves. *) let rec flatten_patterns ~size acc pat = match pat.pat_desc with | Tpat_tuple [ tuple; pat ] when size > 0 -> flatten_patterns ~size:(size - 1) (pat :: acc) tuple | _ -> List.rev (pat :: acc) in let bindops = let_ :: ands in let patterns = flatten_patterns ~size:(List.length ands) [] body.c_lhs in let of_letop (pat, bindop) = of_bop bindop ** of_pattern pat in list_fold of_letop (List.combine patterns bindops) ** of_expression body.c_rhs | Texp_open (od, e) -> app (Module_expr od.open_expr) ** of_expression e and of_function_param fp = of_function_param_kind fp.fp_kind and of_function_param_kind = function | Tparam_pat pat -> of_pattern pat | Tparam_optional_default (pat, exp) -> of_pattern pat ** of_expression exp and of_function_body = function | Tfunction_body exp -> of_expression exp | Tfunction_cases fc -> list_fold of_case fc.cases and of_class_expr_desc = function | Tcl_ident (_, _, cts) -> list_fold of_core_type cts | Tcl_structure cs -> app (Class_structure cs) | Tcl_fun (_, p, es, ce, _) -> list_fold (fun (_, e) -> of_expression e) es ** of_pattern p ** app (Class_expr ce) | Tcl_apply (ce, es) -> list_fold (function | _, None -> id_fold | _, Some e -> of_expression e) es ** app (Class_expr ce) | Tcl_let (_, vbs, es, ce) -> list_fold of_value_binding vbs ** list_fold (fun (_, e) -> of_expression e) es ** app (Class_expr ce) | Tcl_constraint (ce, cto, _, _, _) -> option_fold (fun ct -> app (Class_type ct)) cto ** app (Class_expr ce) | Tcl_open (_, ce) -> app (Class_expr ce) and of_class_field_desc = function | Tcf_inherit (_, ce, _, _, _) -> app (Class_expr ce) | Tcf_val (_, _, _, cfk, _) | Tcf_method (_, _, cfk) -> app (Class_field_kind cfk) | Tcf_constraint (ct1, ct2) -> of_core_type ct1 ** of_core_type ct2 | Tcf_initializer e -> of_expression e | Tcf_attribute _ -> id_fold (*TODO*) and of_module_expr_desc = function | Tmod_ident _ -> id_fold | Tmod_structure str -> app (Structure str) | Tmod_functor (Unit, me) -> of_module_expr me | Tmod_functor (Named (_, _, mt), me) -> of_module_type mt ** of_module_expr me | Tmod_apply (me1, me2, _) -> of_module_expr me1 ** of_module_expr me2 | Tmod_apply_unit me1 -> of_module_expr me1 | Tmod_constraint (me, _, mtc, _) -> of_module_expr me ** app (Module_type_constraint mtc) | Tmod_unpack (e, _) -> of_expression e | Tmod_hole -> id_fold and of_structure_item_desc = function | Tstr_eval (e, _) -> of_expression e | Tstr_value (_, vbs) -> list_fold of_value_binding vbs | Tstr_primitive vd -> app (Value_description vd) | Tstr_type (_, tds) -> list_fold (fun td -> app (Type_declaration td)) tds | Tstr_typext text -> app (Type_extension text) | Tstr_exception texn -> app (Extension_constructor texn.tyexn_constructor) | Tstr_module mb -> app (Module_binding mb) | Tstr_recmodule mbs -> list_fold (fun x -> app (Module_binding x)) mbs | Tstr_modtype mtd -> app (Module_type_declaration mtd) | Tstr_class cds -> list_fold (fun (cd, _) -> app (Class_declaration cd)) cds | Tstr_class_type ctds -> list_fold (fun (_, _, ctd) -> app (Class_type_declaration ctd)) ctds | Tstr_include i -> app (Include_declaration i) | Tstr_open d -> app (Open_declaration d) | Tstr_attribute _ -> id_fold and of_module_type_desc = function | Tmty_ident _ | Tmty_alias _ -> id_fold | Tmty_signature sg -> app (Signature sg) | Tmty_functor (Named (_, _, mt1), mt2) -> of_module_type mt1 ** of_module_type mt2 | Tmty_functor (Unit, mt) -> of_module_type mt | Tmty_with (mt, wcs) -> list_fold (fun (_, _, wc) -> app (With_constraint wc)) wcs ** of_module_type mt | Tmty_typeof me -> of_module_expr me and of_signature_item_desc = function | Tsig_attribute _ -> id_fold | Tsig_open d -> app (Open_description d) | Tsig_value vd -> app (Value_description vd) | Tsig_type (_, tds) -> list_fold (fun td -> app (Type_declaration td)) tds | Tsig_typext text -> app (Type_extension text) | Tsig_exception texn -> app (Extension_constructor texn.tyexn_constructor) | Tsig_module md -> app (Module_declaration md) | Tsig_recmodule mds -> list_fold (fun md -> app (Module_declaration md)) mds | Tsig_modtype mtd -> app (Module_type_declaration mtd) | Tsig_include i -> app (Include_description i) | Tsig_class cds -> list_fold (fun cd -> app (Class_description cd)) cds | Tsig_class_type ctds -> list_fold (fun ctd -> app (Class_type_declaration ctd)) ctds | Tsig_typesubst tds -> (* FIXME: shitty approximation *) list_fold (fun td -> app (Type_declaration td)) tds | Tsig_modsubst _ms -> (* TODO. *) id_fold | Tsig_modtypesubst _mts -> (* TODO. *) id_fold and of_core_type_desc = function | Ttyp_any | Ttyp_var _ -> id_fold | Ttyp_open (_, _, ct) -> of_core_type ct | Ttyp_arrow (_, ct1, ct2) -> of_core_type ct1 ** of_core_type ct2 | Ttyp_tuple cts | Ttyp_constr (_, _, cts) | Ttyp_class (_, _, cts) -> list_fold of_core_type cts | Ttyp_object (cts, _) -> list_fold (fun of_ -> match of_.of_desc with | OTtag (_, ct) | OTinherit ct -> of_core_type ct) cts | Ttyp_poly (_, ct) | Ttyp_alias (ct, _) -> of_core_type ct | Ttyp_variant (rfs, _, _) -> list_fold (fun rf -> app (Row_field rf)) rfs | Ttyp_package pt -> app (Package_type pt) and of_class_type_desc = function | Tcty_constr (_, _, cts) -> list_fold of_core_type cts | Tcty_signature cs -> app (Class_signature cs) | Tcty_arrow (_, ct, clt) -> of_core_type ct ** app (Class_type clt) | Tcty_open (_, ct) -> app (Class_type ct) and of_class_type_field_desc = function | Tctf_inherit ct -> app (Class_type ct) | Tctf_val (_, _, _, ct) | Tctf_method (_, _, _, ct) -> of_core_type ct | Tctf_constraint (ct1, ct2) -> of_core_type ct1 ** of_core_type ct2 | Tctf_attribute _ -> id_fold let of_node = function | Dummy -> id_fold | Pattern { pat_desc; pat_extra = _ } -> of_pattern_desc pat_desc | Expression { exp_desc; exp_extra = _; exp_loc } -> of_expression_desc exp_loc exp_desc | Case { c_lhs; c_guard; c_rhs } -> of_pattern c_lhs ** of_expression c_rhs ** option_fold of_expression c_guard | Class_expr { cl_desc } -> of_class_expr_desc cl_desc | Class_structure { cstr_self; cstr_fields } -> of_pattern cstr_self ** list_fold (fun f -> app (Class_field f)) cstr_fields | Class_field { cf_desc } -> of_class_field_desc cf_desc | Class_field_kind (Tcfk_virtual ct) -> of_core_type ct | Class_field_kind (Tcfk_concrete (_, e)) -> of_expression e | Module_expr { mod_desc } -> of_module_expr_desc mod_desc | Module_type_constraint Tmodtype_implicit -> id_fold | Module_type_constraint (Tmodtype_explicit mt) -> of_module_type mt | Structure { str_items; str_final_env } -> list_fold_with_next (fun next item -> match next with | None -> app (Structure_item (item, str_final_env)) | Some item' -> app (Structure_item (item, item'.str_env))) str_items | Structure_item ({ str_desc }, _) -> of_structure_item_desc str_desc | Module_binding mb -> app (Module_expr mb.mb_expr) ** app (Module_binding_name mb) | Value_binding { vb_pat; vb_expr } -> of_pattern vb_pat ** of_expression vb_expr | Module_type { mty_desc } -> of_module_type_desc mty_desc | Signature { sig_items; sig_final_env } -> list_fold_with_next (fun next item -> match next with | None -> app (Signature_item (item, sig_final_env)) | Some item' -> app (Signature_item (item, item'.sig_env))) sig_items | Signature_item ({ sig_desc }, _) -> of_signature_item_desc sig_desc | Module_declaration md -> of_module_type md.md_type ** app (Module_declaration_name md) | Module_type_declaration mtd -> option_fold of_module_type mtd.mtd_type ** app (Module_type_declaration_name mtd) | With_constraint (Twith_type td | Twith_typesubst td) -> app (Type_declaration td) | With_constraint (Twith_module _ | Twith_modsubst _) -> id_fold | With_constraint (Twith_modtype mt | Twith_modtypesubst mt) -> of_module_type mt | Core_type { ctyp_desc } -> of_core_type_desc ctyp_desc | Package_type { pack_fields } -> list_fold (fun (_, ct) -> of_core_type ct) pack_fields | Row_field rf -> begin match rf.rf_desc with | Ttag (_, _, cts) -> list_fold of_core_type cts | Tinherit ct -> of_core_type ct end | Value_description { val_desc } -> of_core_type val_desc | Type_declaration { typ_params; typ_cstrs; typ_kind; typ_manifest } -> let of_typ_cstrs (ct1, ct2, _) = of_core_type ct1 ** of_core_type ct2 in option_fold of_core_type typ_manifest ** list_fold of_typ_param typ_params ** app (Type_kind typ_kind) ** list_fold of_typ_cstrs typ_cstrs | Type_kind (Ttype_abstract | Ttype_open) -> id_fold | Type_kind (Ttype_variant cds) -> list_fold (fun cd -> app (Constructor_declaration cd)) cds | Type_kind (Ttype_record lds) -> list_fold of_label_declaration lds | Type_extension { tyext_params; tyext_constructors } -> list_fold of_typ_param tyext_params ** list_fold (fun ec -> app (Extension_constructor ec)) tyext_constructors | Extension_constructor { ext_kind = Text_decl (_, carg, cto) } -> option_fold of_core_type cto ** of_constructor_arguments carg | Extension_constructor { ext_kind = Text_rebind _ } -> id_fold | Label_declaration { ld_type } -> of_core_type ld_type | Constructor_declaration { cd_args; cd_res } -> option_fold of_core_type cd_res ** of_constructor_arguments cd_args | Class_type { cltyp_desc } -> of_class_type_desc cltyp_desc | Class_signature { csig_self; csig_fields } -> of_core_type csig_self ** list_fold (fun x -> app (Class_type_field x)) csig_fields | Class_type_field { ctf_desc } -> of_class_type_field_desc ctf_desc | Class_declaration { ci_params; ci_expr } -> app (Class_expr ci_expr) ** list_fold of_typ_param ci_params | Class_description { ci_params; ci_expr } -> app (Class_type ci_expr) ** list_fold of_typ_param ci_params | Class_type_declaration { ci_params; ci_expr } -> app (Class_type ci_expr) ** list_fold of_typ_param ci_params | Method_call _ -> id_fold | Record_field _ -> id_fold | Module_binding_name _ -> id_fold | Module_declaration_name _ -> id_fold | Module_type_declaration_name _ -> id_fold | Open_description _ -> id_fold | Open_declaration od -> app (Module_expr od.open_expr) | Include_declaration i -> of_module_expr i.incl_mod | Include_description i -> of_module_type i.incl_mod | Binding_op { bop_exp = _ } -> id_fold let fold_node f env node acc = of_node node env f acc (** Accessors for information specific to a node *) let string_of_node = function | Dummy -> "dummy" | Pattern p -> let fmt, printer = Format.to_string () in Printtyped.pattern 0 fmt p; printer () | Expression _ -> "expression" | Case _ -> "case" | Class_expr _ -> "class_expr" | Class_structure _ -> "class_structure" | Class_field _ -> "class_field" | Class_field_kind _ -> "class_field_kind" | Module_expr _ -> "module_expr" | Module_type_constraint _ -> "module_type_constraint" | Structure _ -> "structure" | Structure_item _ -> "structure_item" | Module_binding _ -> "module_binding" | Value_binding _ -> "value_binding" | Module_type _ -> "module_type" | Signature _ -> "signature" | Signature_item _ -> "signature_item" | Module_declaration _ -> "module_declaration" | Module_type_declaration _ -> "module_type_declaration" | With_constraint _ -> "with_constraint" | Core_type _ -> "core_type" | Package_type _ -> "package_type" | Row_field _ -> "row_field" | Value_description _ -> "value_description" | Type_declaration _ -> "type_declaration" | Type_kind _ -> "type_kind" | Type_extension _ -> "type_extension" | Extension_constructor _ -> "extension_constructor" | Label_declaration _ -> "label_declaration" | Constructor_declaration _ -> "constructor_declaration" | Class_type _ -> "class_type" | Class_signature _ -> "class_signature" | Class_type_field _ -> "class_type_field" | Class_declaration _ -> "class_declaration" | Class_description _ -> "class_description" | Class_type_declaration _ -> "class_type_declaration" | Binding_op _ -> "binding_op" | Method_call _ -> "method_call" | Record_field _ -> "record_field" | Module_binding_name _ -> "module_binding_name" | Module_declaration_name _ -> "module_declaration_name" | Module_type_declaration_name _ -> "module_type_declaration_name" | Open_description _ -> "open_description" | Open_declaration _ -> "open_declaration" | Include_description _ -> "include_description" | Include_declaration _ -> "include_declaration" let mkloc = Location.mkloc let reloc txt loc = { loc with Location.txt } let mk_lident x = Longident.Lident x let type_constructor_path typ = match Types.get_desc typ with | Types.Tconstr (p, _, _) -> p | _ -> raise Not_found (* Build a fake path for value constructors and labels *) let fake_path { Location.loc; txt = lid } typ name = match type_constructor_path typ with | Path.Pdot (p, _) -> [ (mkloc (Path.Pdot (p, name)) loc, Some lid) ] | Path.Pident _ -> [ (mkloc (Path.Pident (Ident.create_persistent name)) loc, Some lid) ] | _ | (exception Not_found) -> [] let pattern_paths (type k) { Typedtree.pat_desc; pat_extra; _ } = let init = match (pat_desc : k pattern_desc) with | Tpat_construct (lid_loc, { Types.cstr_name; cstr_res; _ }, _, _) -> fake_path lid_loc cstr_res cstr_name | Tpat_var (id, { Location.loc; txt }, _uid) -> [ (mkloc (Path.Pident id) loc, Some (Longident.Lident txt)) ] | Tpat_alias (_, id, loc, _uid) -> [ (reloc (Path.Pident id) loc, Some (Longident.Lident loc.txt)) ] | _ -> [] in List.fold_left ~init pat_extra ~f:(fun acc (extra, _, _) -> match extra with | Tpat_open (path, loc, _) | Tpat_type (path, loc) -> (reloc path loc, Some loc.txt) :: acc | _ -> acc) let module_expr_paths { Typedtree.mod_desc } = match mod_desc with | Tmod_ident (path, loc) -> [ (reloc path loc, Some loc.txt) ] | Tmod_functor (Named (Some id, loc, _), _) -> [ (reloc (Path.Pident id) loc, Option.map ~f:mk_lident loc.txt) ] | _ -> [] let bindop_path { bop_op_name; bop_op_path } = let loc = bop_op_name in let path = bop_op_path in (reloc path loc, Some (Longident.Lident loc.txt)) let expression_paths { Typedtree.exp_desc; exp_extra; _ } = let init = match exp_desc with | Texp_ident (path, loc, _) -> [ (reloc path loc, Some loc.txt) ] | Texp_letop { let_; ands } -> bindop_path let_ :: List.map ~f:bindop_path ands | Texp_new (path, loc, _) -> [ (reloc path loc, Some loc.txt) ] | Texp_instvar (_, path, loc) -> [ (reloc path loc, Some (Lident loc.txt)) ] | Texp_setinstvar (_, path, loc, _) -> [ (reloc path loc, Some (Lident loc.txt)) ] | Texp_override (_, ps) -> List.map ~f:(fun (id, loc, _) -> (reloc (Path.Pident id) loc, Some (Longident.Lident loc.txt))) ps | Texp_letmodule (Some id, loc, _, _, _) -> [ (reloc (Path.Pident id) loc, Option.map ~f:mk_lident loc.txt) ] | Texp_for (id, { Parsetree.ppat_loc = loc; ppat_desc }, _, _, _, _) -> let lid = match ppat_desc with | Ppat_any -> None | Ppat_var { txt } -> Some (Longident.Lident txt) | _ -> assert false in [ (mkloc (Path.Pident id) loc, lid) ] | Texp_construct (lid_loc, { Types.cstr_name; cstr_res; _ }, _) -> fake_path lid_loc cstr_res cstr_name | Texp_open (od, _) -> module_expr_paths od.open_expr | _ -> [] in List.fold_left ~init exp_extra ~f:(fun acc (extra, _, _) -> match extra with | Texp_newtype' (id, label_loc, _) -> let path = Path.Pident id in let lid = Longident.Lident label_loc.txt in (mkloc path label_loc.loc, Some lid) :: acc | _ -> acc) let core_type_paths { Typedtree.ctyp_desc } = match ctyp_desc with | Ttyp_constr (path, loc, _) -> [ (reloc path loc, Some loc.txt) ] | Ttyp_class (path, loc, _) -> [ (reloc path loc, Some loc.txt) ] | _ -> [] let class_expr_paths { Typedtree.cl_desc } = match cl_desc with | Tcl_ident (path, loc, _) -> [ (reloc path loc, Some loc.txt) ] | _ -> [] let class_field_paths { Typedtree.cf_desc } = match cf_desc with | Tcf_val (loc, _, id, _, _) -> [ (reloc (Path.Pident id) loc, Some (Longident.Lident loc.txt)) ] | _ -> [] let structure_item_paths { Typedtree.str_desc } = match str_desc with | Tstr_class_type cls -> List.map ~f:(fun (id, loc, _) -> (reloc (Path.Pident id) loc, Some (Longident.Lident loc.txt))) cls | Tstr_open od -> module_expr_paths od.open_expr | _ -> [] let module_type_paths { Typedtree.mty_desc } = match mty_desc with | Tmty_ident (path, loc) | Tmty_alias (path, loc) -> [ (reloc path loc, Some loc.txt) ] | Tmty_functor (Named (Some id, loc, _), _) -> [ (reloc (Path.Pident id) loc, Option.map ~f:mk_lident loc.txt) ] | Tmty_with (_, ls) -> List.map ~f:(fun (p, l, _) -> (reloc p l, Some l.txt)) ls | _ -> [] let signature_item_paths { Typedtree.sig_desc } = match sig_desc with | Tsig_open { Typedtree.open_expr = open_path, open_txt; _ } -> [ (reloc open_path open_txt, Some open_txt.txt) ] | _ -> [] let with_constraint_paths = function | Twith_module (path, loc) | Twith_modsubst (path, loc) -> [ (reloc path loc, Some loc.txt) ] | _ -> [] let ci_paths { Typedtree.ci_id_name; ci_id_class } = [ ( reloc (Path.Pident ci_id_class) ci_id_name, Some (Longident.Lident ci_id_name.txt) ) ] let node_paths_full = let open Typedtree in function | Pattern p -> pattern_paths p | Expression e -> expression_paths e | Class_expr e -> class_expr_paths e | Class_field f -> class_field_paths f | Module_expr me -> module_expr_paths me | Structure_item (i, _) -> structure_item_paths i | Module_binding_name { mb_id = Some mb_id; mb_name } -> [ (reloc (Path.Pident mb_id) mb_name, Option.map ~f:mk_lident mb_name.txt) ] | Module_type mt -> module_type_paths mt | Signature_item (i, _) -> signature_item_paths i | Module_declaration_name { md_id = Some md_id; md_name } -> [ (reloc (Path.Pident md_id) md_name, Option.map ~f:mk_lident md_name.txt) ] | Module_type_declaration_name { mtd_id; mtd_name } -> [ (reloc (Path.Pident mtd_id) mtd_name, Some (Lident mtd_name.txt)) ] | With_constraint c -> with_constraint_paths c | Core_type ct -> core_type_paths ct | Package_type { pack_path; pack_txt } -> [ (reloc pack_path pack_txt, Some pack_txt.txt) ] | Value_description { val_id; val_name } -> [ (reloc (Path.Pident val_id) val_name, Some (Lident val_name.txt)) ] | Type_declaration { typ_id; typ_name } -> [ (reloc (Path.Pident typ_id) typ_name, Some (Lident typ_name.txt)) ] | Type_extension { tyext_path; tyext_txt } -> [ (reloc tyext_path tyext_txt, Some tyext_txt.txt) ] | Extension_constructor { ext_id; ext_name } -> [ (reloc (Path.Pident ext_id) ext_name, Some (Lident ext_name.txt)) ] | Label_declaration { ld_id; ld_name } -> [ (reloc (Path.Pident ld_id) ld_name, Some (Lident ld_name.txt)) ] | Constructor_declaration { cd_id; cd_name } -> [ (reloc (Path.Pident cd_id) cd_name, Some (Lident cd_name.txt)) ] | Class_declaration ci -> ci_paths ci | Class_description ci -> ci_paths ci | Class_type_declaration ci -> ci_paths ci | Record_field (_, { Types.lbl_res; lbl_name; _ }, lid_loc) -> fake_path lid_loc lbl_res lbl_name | _ -> [] let node_paths t = List.map (node_paths_full t) ~f:fst let node_paths_and_longident t = List.filter_map (node_paths_full t) ~f:(function | _, None -> None | p, Some lid -> Some (p, lid)) let node_is_constructor = function | Constructor_declaration decl -> Some { decl.cd_name with Location.txt = `Declaration decl } | Expression { exp_desc = Texp_construct (loc, desc, _) } -> Some { loc with Location.txt = `Description desc } | Pattern { pat_desc = Tpat_construct (loc, desc, _, _) } -> Some { loc with Location.txt = `Description desc } | Extension_constructor ext_cons -> Some { Location.loc = ext_cons.ext_loc; txt = `Extension_constructor ext_cons } | _ -> None let node_of_binary_part env part = let open Cmt_format in match part with | Partial_structure x -> Structure x | Partial_structure_item x -> Structure_item (x, env) | Partial_expression x -> Expression x | Partial_pattern (_, x) -> Pattern x | Partial_class_expr x -> Class_expr x | Partial_signature x -> Signature x | Partial_signature_item x -> Signature_item (x, env) | Partial_module_type x -> Module_type x let all_holes (env, node) = let rec aux acc (env, node) = let f env node acc = match node with | Expression { exp_desc = Texp_hole; exp_loc; exp_type; exp_env; _ } -> (exp_loc, exp_env, `Exp exp_type) :: acc | Module_expr { mod_desc = Tmod_hole; mod_loc; mod_type; mod_env; _ } -> (mod_loc, mod_env, `Mod mod_type) :: acc | _ -> aux acc (env, node) in fold_node f env node acc in aux [] (env, node) |> List.rev
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>