From 0c1ae52feb9ee7cc1858237d0c17da1cf863c2cc Mon Sep 17 00:00:00 2001 From: "Kartik K. Agaram" Date: Fri, 22 Jul 2016 13:55:25 -0700 Subject: 3123 Bugfix: permit dummy product when trying to convert exclusive containers. The 'status' product is still required, however. Without it there's no point to calling 'maybe-convert'. --- 033exclusive_container.cc | 21 ++++++++++++++++----- 1 file changed, 16 insertions(+), 5 deletions(-) diff --git a/033exclusive_container.cc b/033exclusive_container.cc index 8f79e980..462521dd 100644 --- a/033exclusive_container.cc +++ b/033exclusive_container.cc @@ -153,11 +153,13 @@ case MAYBE_CONVERT: { const reagent& variant = variant_type(base, tag); trace(9999, "mem") << "storing 1 in location " << status.value << end(); put(Memory, status.value, 1); - // Write Memory in Successful MAYBE_CONVERT in Run - for (int i = 0; i < size_of(variant); ++i) { - double val = get_or_insert(Memory, base_address+/*skip tag*/1+i); - trace(9999, "mem") << "storing " << no_scientific(val) << " in location " << product.value+i << end(); - put(Memory, product.value+i, val); + if (!is_dummy(product)) { + // Write Memory in Successful MAYBE_CONVERT in Run + for (int i = 0; i < size_of(variant); ++i) { + double val = get_or_insert(Memory, base_address+/*skip tag*/1+i); + trace(9999, "mem") << "storing " << no_scientific(val) << " in location " << product.value+i << end(); + put(Memory, product.value+i, val); + } } } else { @@ -193,6 +195,15 @@ def main [ ] +error: main: 'maybe-convert 12:number-or-point/unsafe, 1:variant' should write to point but '20' has type number +:(scenario maybe_convert_dummy_product) +def main [ + 12:number <- copy 1 + 13:number <- copy 35 + 14:number <- copy 36 + _, 21:boolean <- maybe-convert 12:number-or-point/unsafe, 1:variant +] +$error: 0 + //:: Allow exclusive containers to be defined in mu code. :(scenario exclusive_container) -- cgit 1.4.1-2-gfad0