Commit Graph

1 Commits

Author SHA1 Message Date
Julien Fischer
6ab4ec3980 Fix a bug reported by Peter Hawkins.
Estimated hours taken: 8
Branches: main, release

Fix a bug reported by Peter Hawkins.

compiler/superhomogeneous.m:
	When converting lambda expressions into superhomogeneous form,
	position the compiler created unifications that correspond to
	output arguments *after* the original body of the lambda.
	Placing them all before the body, leads to problems if the body
	is impure because mode analysis cannot reorder the unifications
	over the impure goal as it needs to in order for the lambda to
	be mode correct.

	XXX According to a comment, intermod.m:643, we allow head
	unifications to be reordered w.r.t impure goals, but this doesn't
	seem to extend to lambda expressions for some reason.  Actually,
	the rules for reordering over impure goals should be less
	strict then they currently are, at least for construction
	and assignment unifications.  (I'll look into this separately though).

compiler/arg_info.m:
	Mention how the predicates in this module diff from the newly
	introduced partition_args_and_lambda_vars in superhomogenous.m.
	(Because the former cannot handle undefined modes.)

compiler/state_var.m:
	Generalise the predicate finish_head_and_body/6 so that it works
	on an arbitrary number of conjoined goals.

compiler/mode_util.m:
	Add a predicate to test whether a mode is undefined.

compiler/add_aditi.m:
compiler/add_clause.m:
	Conform to the above changes.

tests/valid/Mmakefile:
tests/valid/impure_lambda_bug.m:
	Test case for the above bug.
2005-08-12 02:33:10 +00:00