<linkrel="alternate icon"type="image/png"href="../favicon-32x32.png"><styletype="text/css">#crate-search{background-image:url("../down-arrow.svg");}</style></head><bodyclass="rustdoc mod"><!--[if lte IE 8]><div class="warning">This old browser is unsupported and will most likely display funky things.</div><![endif]--><navclass="sidebar"><divclass="sidebar-menu">☰</div><ahref='../abstutil/index.html'><divclass='logo-container rust-logo'><imgsrc='../rust-logo.png'alt='logo'></div></a><pclass="location">Crate abstutil</p><divclass="block version"><p>Version 0.1.0</p></div><divclass="sidebar-elems"><aid="all-types"href="all.html"><p>See all abstutil's items</p></a><divclass="block items"><ul><li><ahref="#modules">Modules</a></li><li><ahref="#structs">Structs</a></li><li><ahref="#enums">Enums</a></li><li><ahref="#constants">Constants</a></li><li><ahref="#traits">Traits</a></li><li><ahref="#functions">Functions</a></li></ul></div><pclass="location"></p><script>window.sidebarCurrent={name:"abstutil",ty:"mod",relpath:"../"};</script></div></nav><divclass="theme-picker"><buttonid="theme-picker"aria-label="Pick another theme!"aria-haspopup="menu"><imgsrc="../brush.svg"width="18"alt="Pick another theme!"></button><divid="theme-choices"role="menu"></div></div><scriptsrc="../theme.js"></script><navclass="sub"><formclass="search-form"><divclass="search-container"><div><selectid="crate-search"><optionvalue="All crates">All crates</option></select><inputclass="search-input"name="search"disabledautocomplete="off"spellcheck="false"placeholder="Click or press ‘S’ to search, ‘?’ for more options…"type="search"></div><spanclass="help-button">?</span>
<aid="settings-menu"href="../settings.html"><imgsrc="../wheel.svg"width="18"alt="Change settings"></a></div></form></nav><sectionid="main"class="content"><h1class="fqn"><spanclass="out-of-band"><spanid="render-detail"><aid="toggle-all-docs"href="javascript:void(0)"title="collapse all docs">[<spanclass="inner">−</span>]</a></span><aclass="srclink"href="../src/abstutil/lib.rs.html#1-42"title="goto source code">[src]</a></span><spanclass="in-band">Crate <aclass="mod"href="">abstutil</a></span></h1><divclass="docblock"><p>The contents of this crate need to be organized better:</p>
<table><trclass="module-item"><td><aclass="mod"href="abst_data/index.html"title="abstutil::abst_data mod">abst_data</a></td><tdclass="docblock-short"></td></tr><trclass="module-item"><td><aclass="mod"href="abst_paths/index.html"title="abstutil::abst_paths mod">abst_paths</a></td><tdclass="docblock-short"><p>Generate paths for different A/B Street files</p>
</td></tr><trclass="module-item"><td><aclass="mod"href="cli/index.html"title="abstutil::cli mod">cli</a></td><tdclass="docblock-short"></td></tr><trclass="module-item"><td><aclass="mod"href="collections/index.html"title="abstutil::collections mod">collections</a></td><tdclass="docblock-short"></td></tr><trclass="module-item"><td><aclass="mod"href="io/index.html"title="abstutil::io mod">io</a></td><tdclass="docblock-short"></td></tr><trclass="module-item"><td><aclass="mod"href="io_native/index.html"title="abstutil::io_native mod">io_native</a></td><tdclass="docblock-short"><p>Normal file IO using the filesystem</p>
<table><trclass="module-item"><td><aclass="struct"href="struct.CmdArgs.html"title="abstutil::CmdArgs struct">CmdArgs</a></td><tdclass="docblock-short"><p>Yet another barebones command-line flag parsing library.</p>
</td></tr><trclass="module-item"><td><aclass="struct"href="struct.Counter.html"title="abstutil::Counter struct">Counter</a></td><tdclass="docblock-short"></td></tr><trclass="module-item"><td><aclass="struct"href="struct.DataPacks.html"title="abstutil::DataPacks struct">DataPacks</a></td><tdclass="docblock-short"><p>Player-chosen groups of files to opt into downloading</p>
</td></tr><trclass="module-item"><td><aclass="struct"href="struct.Entry.html"title="abstutil::Entry struct">Entry</a></td><tdclass="docblock-short"><p>A single file</p>
</td></tr><trclass="module-item"><td><aclass="struct"href="struct.FileWithProgress.html"title="abstutil::FileWithProgress struct">FileWithProgress</a></td><tdclass="docblock-short"></td></tr><trclass="module-item"><td><aclass="struct"href="struct.FixedMap.html"title="abstutil::FixedMap struct">FixedMap</a></td><tdclass="docblock-short"><p>A drop-in replacement for <code>BTreeMap</code>, where the keys have the property of being array indices.
</td></tr><trclass="module-item"><td><aclass="struct"href="struct.Manifest.html"title="abstutil::Manifest struct">Manifest</a></td><tdclass="docblock-short"><p>A list of all canonical data files for A/B Street that're uploaded somewhere. The file formats
</td></tr><trclass="module-item"><td><aclass="struct"href="struct.MapName.html"title="abstutil::MapName struct">MapName</a></td><tdclass="docblock-short"><p>A single map is identified using this. Using a struct makes refactoring later easier, to
</td></tr><trclass="module-item"><td><aclass="struct"href="struct.MultiMap.html"title="abstutil::MultiMap struct">MultiMap</a></td><tdclass="docblock-short"></td></tr><trclass="module-item"><td><aclass="struct"href="struct.Tags.html"title="abstutil::Tags struct">Tags</a></td><tdclass="docblock-short"><p>Convenience functions around a string->string map</p>
</td></tr><trclass="module-item"><td><aclass="struct"href="struct.VecMap.html"title="abstutil::VecMap struct">VecMap</a></td><tdclass="docblock-short"><p>Use when your key is just PartialEq, not Ord or Hash.</p>
<table><trclass="module-item"><td><aclass="trait"href="trait.IndexableKey.html"title="abstutil::IndexableKey trait">IndexableKey</a></td><tdclass="docblock-short"><p>Use with <code>FixedMap</code>. From a particular key, extract a <code>usize</code>. These values should be
</td></tr><trclass="module-item"><td><aclass="fn"href="fn.deserialize_btreemap.html"title="abstutil::deserialize_btreemap fn">deserialize_btreemap</a></td><tdclass="docblock-short"><p>Deserializes a BTreeMap from a list of tuples. Necessary when the keys are structs; see
</td></tr><trclass="module-item"><td><aclass="fn"href="fn.deserialize_hashmap.html"title="abstutil::deserialize_hashmap fn">deserialize_hashmap</a></td><tdclass="docblock-short"><p>Deserializes a HashMap from a list of tuples.</p>
</td></tr><trclass="module-item"><td><aclass="fn"href="fn.deserialize_multimap.html"title="abstutil::deserialize_multimap fn">deserialize_multimap</a></td><tdclass="docblock-short"><p>Deserializes a MultiMap.</p>
</td></tr><trclass="module-item"><td><aclass="fn"href="fn.deserialize_usize.html"title="abstutil::deserialize_usize fn">deserialize_usize</a></td><tdclass="docblock-short"><p>Deserializes a <code>usize</code> from a <code>u32</code>.</p>
</td></tr><trclass="module-item"><td><aclass="fn"href="fn.from_binary.html"title="abstutil::from_binary fn">from_binary</a></td><tdclass="docblock-short"><p>Deserializes an object from the bincode format.</p>
</td></tr><trclass="module-item"><td><aclass="fn"href="fn.from_binary_reader.html"title="abstutil::from_binary_reader fn">from_binary_reader</a></td><tdclass="docblock-short"><p>Deserializes an object from the bincode format, from a reader.</p>
</td></tr><trclass="module-item"><td><aclass="fn"href="fn.from_json.html"title="abstutil::from_json fn">from_json</a></td><tdclass="docblock-short"><p>Deserializes an object from a JSON string.</p>
</td></tr><trclass="module-item"><td><aclass="fn"href="fn.from_json_reader.html"title="abstutil::from_json_reader fn">from_json_reader</a></td><tdclass="docblock-short"><p>Deserializes an object from JSON, from a reader.</p>
</td></tr><trclass="module-item"><td><aclass="fn"href="fn.list_all_objects.html"title="abstutil::list_all_objects fn">list_all_objects</a></td><tdclass="docblock-short"><p>Just list all things from a directory, return sorted by name, with file extension removed.</p>
</td></tr><trclass="module-item"><td><aclass="fn"href="fn.list_dir.html"title="abstutil::list_dir fn">list_dir</a></td><tdclass="docblock-short"><p>Returns full paths</p>
</td></tr><trclass="module-item"><td><aclass="fn"href="fn.load_all_objects.html"title="abstutil::load_all_objects fn">load_all_objects</a></td><tdclass="docblock-short"><p>Load all serialized things from a directory, return sorted by name, with file extension removed.
</td></tr><trclass="module-item"><td><aclass="fn"href="fn.maybe_read_binary.html"title="abstutil::maybe_read_binary fn">maybe_read_binary</a></td><tdclass="docblock-short"></td></tr><trclass="module-item"><td><aclass="fn"href="fn.maybe_read_json.html"title="abstutil::maybe_read_json fn">maybe_read_json</a></td><tdclass="docblock-short"></td></tr><trclass="module-item"><td><aclass="fn"href="fn.must_read_object.html"title="abstutil::must_read_object fn">must_read_object</a></td><tdclass="docblock-short"><p>May be a JSON or binary file. Panics on failure.</p>
</td></tr><trclass="module-item"><td><aclass="fn"href="fn.must_run_cmd.html"title="abstutil::must_run_cmd fn">must_run_cmd</a></td><tdclass="docblock-short"><p>Runs a command, asserts success. STDOUT and STDERR aren't touched.</p>
</td></tr><trclass="module-item"><td><aclass="fn"href="fn.parent_path.html"title="abstutil::parent_path fn">parent_path</a></td><tdclass="docblock-short"></td></tr><trclass="module-item"><td><aclass="fn"href="fn.parse_scenario_path.html"title="abstutil::parse_scenario_path fn">parse_scenario_path</a></td><tdclass="docblock-short"><p>Extract the map and scenario name from a path. Crashes if the input is strange.</p>
</td></tr><trclass="module-item"><td><aclass="fn"href="fn.path.html"title="abstutil::path fn">path</a></td><tdclass="docblock-short"></td></tr><trclass="module-item"><td><aclass="fn"href="fn.path_all_edits.html"title="abstutil::path_all_edits fn">path_all_edits</a></td><tdclass="docblock-short"></td></tr><trclass="module-item"><td><aclass="fn"href="fn.path_all_saves.html"title="abstutil::path_all_saves fn">path_all_saves</a></td><tdclass="docblock-short"></td></tr><trclass="module-item"><td><aclass="fn"href="fn.path_all_scenarios.html"title="abstutil::path_all_scenarios fn">path_all_scenarios</a></td><tdclass="docblock-short"></td></tr><trclass="module-item"><td><aclass="fn"href="fn.path_camera_state.html"title="abstutil::path_camera_state fn">path_camera_state</a></td><tdclass="docblock-short"></td></tr><trclass="module-item"><td><aclass="fn"href="fn.path_edits.html"title="abstutil::path_edits fn">path_edits</a></td><tdclass="docblock-short"></td></tr><trclass="module-item"><td><aclass="fn"href="fn.path_player.html"title="abstutil::path_player fn">path_player</a></td><tdclass="docblock-short"></td></tr><trclass="module-item"><td><aclass="fn"href="fn.path_popdat.html"title="abstutil::path_popdat fn">path_popdat</a></td><tdclass="docblock-short"></td></tr><trclass="module-item"><td><aclass="fn"href="fn.path_prebaked_results.html"title="abstutil::path_prebaked_results fn">path_prebaked_results</a></td><tdclass="docblock-short"></td></tr><trclass="module-item"><td><aclass="fn"href="fn.path_raw_map.html"title="abstutil::path_raw_map fn">path_raw_map</a></td><tdclass="docblock-short"></td></tr><trclass="module-item"><td><aclass="fn"href="fn.path_save.html"title="abstutil::path_save fn">path_save</a></td><tdclass="docblock-short"></td></tr><trclass="module-item"><td><aclass="fn"href="fn.path_scenario.html"title="abstutil::path_scenario fn">path_scenario</a></td><tdclass="docblock-short"></td></tr><trclass="module-item"><td><aclass="fn"href="fn.plain_list_names.html"title="abstutil::plain_list_names fn">plain_list_names</a></td><tdclass="docblock-short"></td></tr><trclass="module-item"><td><aclass="fn"href="fn.prettyprint_time.html"title="abstutil::prettyprint_time fn">prettyprint_time</a></td><tdclass="docblock-short"></td></tr><trclass="module-item"><td><aclass="fn"href="fn.prettyprint_usize.html"title="abstutil::prettyprint_usize fn">prettyprint_usize</a></td><tdclass="docblock-short"></td></tr><trclass="module-item"><td><aclass="fn"href="fn.read_binary.html"title="abstutil::read_binary fn">read_binary</a></td><tdclass="docblock-short"></td></tr><trclass="module-item"><td><aclass="fn"href="fn.read_json.html"title="abstutil::read_json fn">read_json</a></td><tdclass="docblock-short"></td></tr><trclass="module-item"><td><aclass="fn"href="fn.read_object.html"title="abstutil::read_object fn">read_object</a></td><tdclass="docblock-short"><p>May be a JSON or binary file</p>
</td></tr><trclass="module-item"><td><aclass="fn"href="fn.retain_btreemap.html"title="abstutil::retain_btreemap fn">retain_btreemap</a></td><tdclass="docblock-short"></td></tr><trclass="module-item"><td><aclass="fn"href="fn.retain_btreeset.html"title="abstutil::retain_btreeset fn">retain_btreeset</a></td><tdclass="docblock-short"></td></tr><trclass="module-item"><td><aclass="fn"href="fn.serialize_btreemap.html"title="abstutil::serialize_btreemap fn">serialize_btreemap</a></td><tdclass="docblock-short"><p>Serializes a BTreeMap as a list of tuples. Necessary when the keys are structs; see
</td></tr><trclass="module-item"><td><aclass="fn"href="fn.serialize_hashmap.html"title="abstutil::serialize_hashmap fn">serialize_hashmap</a></td><tdclass="docblock-short"><p>Serializes a HashMap as a list of tuples, first sorting by the keys. This ensures the
</td></tr><trclass="module-item"><td><aclass="fn"href="fn.serialize_multimap.html"title="abstutil::serialize_multimap fn">serialize_multimap</a></td><tdclass="docblock-short"><p>Serializes a MultiMap.</p>
</td></tr><trclass="module-item"><td><aclass="fn"href="fn.serialize_usize.html"title="abstutil::serialize_usize fn">serialize_usize</a></td><tdclass="docblock-short"><p>Serializes a <code>usize</code> as a <code>u32</code> to save space. Useful when you need <code>usize</code> for indexing, but
</td></tr><trclass="module-item"><td><aclass="fn"href="fn.serialized_size_bytes.html"title="abstutil::serialized_size_bytes fn">serialized_size_bytes</a></td><tdclass="docblock-short"><p>The number of bytes for an object serialized to bincode.</p>
</td></tr><trclass="module-item"><td><aclass="fn"href="fn.slurp_file.html"title="abstutil::slurp_file fn">slurp_file</a></td><tdclass="docblock-short"></td></tr><trclass="module-item"><td><aclass="fn"href="fn.to_json.html"title="abstutil::to_json fn">to_json</a></td><tdclass="docblock-short"><p>Stringifies an object to nicely formatted JSON.</p>
</td></tr><trclass="module-item"><td><aclass="fn"href="fn.to_json_terse.html"title="abstutil::to_json_terse fn">to_json_terse</a></td><tdclass="docblock-short"><p>Stringifies an object to terse JSON.</p>