adjust comments
This commit is contained in:
parent
8468c40fde
commit
c6ed01cab3
@ -12,9 +12,42 @@
|
|||||||
* match against the current list of values. If those patterns match, then
|
* match against the current list of values. If those patterns match, then
|
||||||
* the arm listed in the match is the correct arm. A given arm may have
|
* the arm listed in the match is the correct arm. A given arm may have
|
||||||
* multiple corresponding match entries, one for each alternative that
|
* multiple corresponding match entries, one for each alternative that
|
||||||
* remains. As we proceed these sets of matches are adjusted. Anyway this
|
* remains. As we proceed these sets of matches are adjusted by the various
|
||||||
* part I am pretty vague on. Perhaps I or someone else can add more
|
* `enter_XXX()` functions, each of which adjusts the set of options given
|
||||||
* documentation when they understand it. :)
|
* some information about the value which has been matched.
|
||||||
|
*
|
||||||
|
* So, initially, there is one value and N matches, each of which have one
|
||||||
|
* constituent pattern. N here is usually the number of arms but may be
|
||||||
|
* greater, if some arms have multiple alternatives. For example, here:
|
||||||
|
*
|
||||||
|
* enum Foo { A, B(int), C(uint, uint) }
|
||||||
|
* match foo {
|
||||||
|
* A => ...,
|
||||||
|
* B(x) => ...,
|
||||||
|
* C(1u, 2) => ...,
|
||||||
|
* C(_) => ...
|
||||||
|
* }
|
||||||
|
*
|
||||||
|
* The value would be `foo`. There would be four matches, each of which
|
||||||
|
* contains one pattern (and, in one case, a guard). We could collect the
|
||||||
|
* various options and then compile the code for the case where `foo` is an
|
||||||
|
* `A`, a `B`, and a `C`. When we generate the code for `C`, we would (1)
|
||||||
|
* drop the two matches that do not match a `C` and (2) expand the other two
|
||||||
|
* into two patterns each. In the first case, the two patterns would be `1u`
|
||||||
|
* and `2`, and the in the second case the _ pattern would be expanded into
|
||||||
|
* `_` and `_`. The two values are of course the arguments to `C`.
|
||||||
|
*
|
||||||
|
* Here is a quick guide to the various functions:
|
||||||
|
*
|
||||||
|
* - `compile_submatch()`: The main workhouse. It takes a list of values and
|
||||||
|
* a list of matches and finds the various possibilities that could occur.
|
||||||
|
*
|
||||||
|
* - `enter_XXX()`: modifies the list of matches based on some information about
|
||||||
|
* the value that has been matched. For example, `enter_rec_or_struct()`
|
||||||
|
* adjusts the values given that a record or struct has been matched. This is
|
||||||
|
* an infallible pattern, so *all* of the matches must be either wildcards or
|
||||||
|
* record/struct patterns. `enter_opt()` handles the fallible cases, and it is
|
||||||
|
* correspondingly more complex.
|
||||||
*
|
*
|
||||||
* ## Bindings
|
* ## Bindings
|
||||||
*
|
*
|
||||||
|
@ -270,9 +270,8 @@ fn ensure_supertraits(ccx: @crate_ctxt,
|
|||||||
*
|
*
|
||||||
* # Parameters
|
* # Parameters
|
||||||
*
|
*
|
||||||
* - impl_m: the method in the impl
|
|
||||||
* - impl_tps: the type params declared on the impl itself (not the method!)
|
* - impl_tps: the type params declared on the impl itself (not the method!)
|
||||||
* - impl_body_id: the id of the method body from the impl
|
* - cm: info about the method we are checking
|
||||||
* - trait_m: the method in the trait
|
* - trait_m: the method in the trait
|
||||||
* - trait_substs: the substitutions used on the type of the trait
|
* - trait_substs: the substitutions used on the type of the trait
|
||||||
* - self_ty: the self type of the impl
|
* - self_ty: the self type of the impl
|
||||||
@ -357,9 +356,6 @@ fn compare_impl_method(tcx: ty::ctxt,
|
|||||||
// a free region. So, for example, if the impl type is
|
// a free region. So, for example, if the impl type is
|
||||||
// "&self/str", then this would replace the self type with a free
|
// "&self/str", then this would replace the self type with a free
|
||||||
// region `self`.
|
// region `self`.
|
||||||
//
|
|
||||||
// Note: Ideal would be to use the node-id of the method body here,
|
|
||||||
// not the node id of the method itself.
|
|
||||||
let dummy_self_r = ty::re_free(cm.body_id, ty::br_self);
|
let dummy_self_r = ty::re_free(cm.body_id, ty::br_self);
|
||||||
let self_ty = replace_bound_self(tcx, self_ty, dummy_self_r);
|
let self_ty = replace_bound_self(tcx, self_ty, dummy_self_r);
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user