about summary refs log tree commit diff stats
diff options
context:
space:
mode:
authorKartik K. Agaram <vc@akkartik.com>2015-10-30 21:12:54 -0700
committerKartik K. Agaram <vc@akkartik.com>2015-10-30 21:12:54 -0700
commita4f12265bee3842e1ff71a601a5f4dbcc3b1db7d (patch)
tree414359fbcdbf0122550ae963d276d991750b5bd8
parente3cb4d0905bdfb1c0b9d520c9c0089cffc09e339 (diff)
downloadmu-a4f12265bee3842e1ff71a601a5f4dbcc3b1db7d.tar.gz
2330 - support generic containers in 'get'
-rw-r--r--058generic_container.cc57
1 files changed, 53 insertions, 4 deletions
diff --git a/058generic_container.cc b/058generic_container.cc
index 75b2188d..b192dbc3 100644
--- a/058generic_container.cc
+++ b/058generic_container.cc
@@ -75,15 +75,15 @@ if (type->value >= START_TYPE_INGREDIENTS
 :(before "End size_of(type) Container Cases")
 if (t.elements.at(i)->value >= START_TYPE_INGREDIENTS) {
   trace(9999, "type") << "checking size of type ingredient\n";
-  result += size_of_type_ingredient(t.elements.at(i)->value - START_TYPE_INGREDIENTS,
-                                    type->right);
+  result += size_of_type_ingredient(t.elements.at(i), type->right);
   continue;
 }
 
 :(code)
 // generic version of size_of
-long long int size_of_type_ingredient(long long int type_ingredient_index, const type_tree* rest_of_type) {
-  const type_tree* curr = rest_of_type;
+long long int size_of_type_ingredient(const type_tree* element_template, const type_tree* rest_of_use) {
+  long long int type_ingredient_index = element_template->value - START_TYPE_INGREDIENTS;
+  const type_tree* curr = rest_of_use;
   while (type_ingredient_index > 0) {
     assert(curr);
     --type_ingredient_index;
@@ -97,3 +97,52 @@ long long int size_of_type_ingredient(long long int type_ingredient_index, const
     tmp.right = new type_tree(*curr->right);
   return size_of(&tmp);
 }
+
+:(scenario get_on_generic_container)
+container foo:_t [
+  x:_t
+  y:number
+]
+recipe main [
+  1:foo:point <- merge 14, 15, 16
+  2:number <- get 1:foo:point, 1:offset
+]
++mem: storing 16 in location 2
+
+:(before "End GET field Cases")
+if (Type[base_type].elements.at(i)->value >= START_TYPE_INGREDIENTS) {
+  src += size_of_type_ingredient(Type[base_type].elements.at(i), base.type->right);
+  continue;
+}
+
+:(scenario get_address_on_generic_container)
+container foo:_t [
+  x:_t
+  y:number
+]
+recipe main [
+  10:foo:point <- merge 14, 15, 16
+  1:address:number <- get-address 10:foo:point, 1:offset
+]
++mem: storing 12 in location 1
+
+:(before "End GET_ADDRESS field Cases")
+if (Type[base_type].elements.at(i)->value >= START_TYPE_INGREDIENTS) {
+  result += size_of_type_ingredient(Type[base_type].elements.at(i), base.type->right);
+  continue;
+}
+
+:(scenario get_on_generic_container_inside_generic_container)
+container foo:_t [
+  x:_t
+  y:number
+]
+container bar [
+  x:foo:point
+  y:number
+]
+recipe main [
+  1:bar <- merge 14, 15, 16, 17
+  2:number <- get 1:bar, 1:offset
+]
++mem: storing 17 in location 2