/// A simple map based on a vector for small integer keys. Space requirements /// are O(highest integer key). import option::none; import option::some; // FIXME: Should not be @; there's a bug somewhere in rustc that requires this // to be. type smallintmap = @{mutable v: [mutable option::t]}; fn mk<@T>() -> smallintmap { let v: [mutable option::t] = ~[mutable]; ret @{mutable v: v}; } fn insert<@T>(m: &smallintmap, key: uint, val: &T) { vec::grow_set[option::t](m.v, key, none[T], some[T](val)); } fn find<@T>(m: &smallintmap, key: uint) -> option::t { if key < vec::len[option::t](m.v) { ret m.v.(key); } ret none[T]; } fn get<@T>(m: &smallintmap, key: uint) -> T { alt find[T](m, key) { none[T]. { log_err "smallintmap::get(): key not present"; fail; } some[T](v) { ret v; } } } fn contains_key<@T>(m: &smallintmap, key: uint) -> bool { ret !option::is_none(find[T](m, key)); } fn truncate<@T>(m: &smallintmap, len: uint) { m.v = vec::slice_mut[option::t](m.v, 0u, len); } fn max_key(m: &smallintmap) -> uint { ret vec::len[option::t](m.v); }