// Copyright 2012 The Rust Project Developers. See the COPYRIGHT // file at the top-level directory of this distribution and at // http://rust-lang.org/COPYRIGHT. // // Licensed under the Apache License, Version 2.0 or the MIT license // , at your // option. This file may not be copied, modified, or distributed // except according to those terms. /** * A function that returns a hash of a value * * The hash should concentrate entropy in the lower bits. */ type HashFn = proc(K):'static -> uint; type EqFn = proc(K, K):'static -> bool; struct LM { resize_at: uint, size: uint } enum HashMap { HashMap_(LM) } fn linear_map() -> HashMap { HashMap_(LM{ resize_at: 32, size: 0}) } impl HashMap { pub fn len(&mut self) -> uint { match *self { HashMap_(l) => l.size } } } pub fn main() { let mut m = box linear_map::<(),()>(); assert_eq!(m.len(), 0); }