about summary refs log blame commit diff stats
path: root/072array.mu
blob: fcd1fcb76b36bac5a5acad843b417bd61559a07f (plain) (tree)
artik.com> 2015-07-28 14:33:22 -0700 1868 - start using naked literals everywhere' href='/akkartik/mu/commit/062array.mu?h=main&id=bc6436927640603675e2e700007f53c5ab213869'>bc643692 ^
1
2
3
4
5
6

                          

                                                               
   
                         







                                              
                                                        
             
                           

                           
                                                            

                               

        
                                        
                    
                    

                           

                                                 
                                                            
                                                                 
                                                     

                           

        
               
 
scenario array-from-args [
  run [
    1:address:shared:array:character <- new-array 0, 1, 2
    2:array:character <- copy *1:address:shared:array:character
  ]
  memory-should-contain [
    2 <- 3  # array length
    3 <- 0
    4 <- 1
    5 <- 2
  ]
]

# create an array out of a list of scalar args
def new-array -> result:address:shared:array:character [
  local-scope
  capacity:number <- copy 0
  {
    # while read curr-value
    curr-value:character, exists?:boolean <- next-ingredient
    break-unless exists?
    capacity <- add capacity, 1
    loop
  }
  result <- new character:type, capacity
  rewind-ingredients
  i:number <- copy 0
  {
    # while read curr-value
    done?:boolean <- greater-or-equal i, capacity
    break-if done?
    curr-value:character, exists?:boolean <- next-ingredient
    assert exists?, [error in rewinding ingredients to new-array]
    tmp:address:character <- index-address *result, i
    *tmp <- copy curr-value
    i <- add i, 1
    loop
  }
  return result
]