2013-02-28 07:15:32 -06:00
|
|
|
// Copyright 2012-2013 The Rust Project Developers. See the COPYRIGHT
|
2012-12-03 18:48:01 -06:00
|
|
|
// file at the top-level directory of this distribution and at
|
|
|
|
// http://rust-lang.org/COPYRIGHT.
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
|
|
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
|
|
|
// option. This file may not be copied, modified, or distributed
|
|
|
|
// except according to those terms.
|
|
|
|
|
2012-09-19 18:52:32 -05:00
|
|
|
/*!
|
|
|
|
|
2013-06-13 20:41:11 -05:00
|
|
|
# The Rust standard library
|
2012-09-19 18:52:32 -05:00
|
|
|
|
2013-06-17 02:07:52 -05:00
|
|
|
The Rust standard library is a group of interrelated modules defining
|
|
|
|
the core language traits, operations on built-in data types, collections,
|
|
|
|
platform abstractions, the task scheduler, runtime support for language
|
|
|
|
features and other common functionality.
|
|
|
|
|
|
|
|
`std` includes modules corresponding to each of the integer types,
|
|
|
|
each of the floating point types, the `bool` type, tuples, characters,
|
|
|
|
strings (`str`), vectors (`vec`), managed boxes (`managed`), owned
|
|
|
|
boxes (`owned`), and unsafe and borrowed pointers (`ptr`, `borrowed`).
|
|
|
|
Additionally, `std` provides pervasive types (`option` and `result`),
|
|
|
|
task creation and communication primitives (`task`, `comm`), platform
|
|
|
|
abstractions (`os` and `path`), basic I/O abstractions (`io`), common
|
|
|
|
traits (`kinds`, `ops`, `cmp`, `num`, `to_str`), and complete bindings
|
|
|
|
to the C standard library (`libc`).
|
2012-09-19 18:52:32 -05:00
|
|
|
|
2013-06-13 20:41:11 -05:00
|
|
|
# Standard library injection and the Rust prelude
|
2013-03-24 20:38:17 -05:00
|
|
|
|
2013-06-13 20:41:11 -05:00
|
|
|
`std` is imported at the topmost level of every crate by default, as
|
2013-03-24 20:38:17 -05:00
|
|
|
if the first line of each crate was
|
2012-09-19 18:52:32 -05:00
|
|
|
|
2013-06-13 20:41:11 -05:00
|
|
|
extern mod std;
|
2013-03-24 20:38:17 -05:00
|
|
|
|
2013-06-13 20:41:11 -05:00
|
|
|
This means that the contents of std can be accessed from any context
|
|
|
|
with the `std::` path prefix, as in `use std::vec`, `use std::task::spawn`,
|
2013-03-24 20:38:17 -05:00
|
|
|
etc.
|
|
|
|
|
2013-06-13 20:41:11 -05:00
|
|
|
Additionally, `std` contains a `prelude` module that reexports many of the
|
2013-06-17 02:07:52 -05:00
|
|
|
most common types, traits and functions. The contents of the prelude are
|
2013-04-01 14:11:07 -05:00
|
|
|
imported into every *module* by default. Implicitly, all modules behave as if
|
2013-03-24 20:38:17 -05:00
|
|
|
they contained the following prologue:
|
|
|
|
|
2013-06-13 20:41:11 -05:00
|
|
|
use std::prelude::*;
|
2012-09-19 18:52:32 -05:00
|
|
|
|
|
|
|
*/
|
|
|
|
|
2012-11-30 02:47:45 -06:00
|
|
|
|
2013-05-17 17:28:44 -05:00
|
|
|
#[link(name = "std",
|
2013-07-08 12:25:45 -05:00
|
|
|
vers = "0.8-pre",
|
2011-12-05 18:46:37 -06:00
|
|
|
uuid = "c70c24a7-5551-4f73-8e37-380b11d80be8",
|
2013-06-13 20:41:11 -05:00
|
|
|
url = "https://github.com/mozilla/rust/tree/master/src/libstd")];
|
2011-12-05 18:46:37 -06:00
|
|
|
|
2013-06-13 20:41:11 -05:00
|
|
|
#[comment = "The Rust standard library"];
|
2013-03-01 10:41:31 -06:00
|
|
|
#[license = "MIT/ASL2"];
|
2011-12-08 23:08:23 -06:00
|
|
|
#[crate_type = "lib"];
|
2011-12-05 18:46:37 -06:00
|
|
|
|
2013-05-17 15:12:42 -05:00
|
|
|
// Don't link to std. We are std.
|
|
|
|
#[no_std];
|
2012-04-19 03:00:52 -05:00
|
|
|
|
2012-09-09 16:51:56 -05:00
|
|
|
#[deny(non_camel_case_types)];
|
2013-05-28 16:35:52 -05:00
|
|
|
#[deny(missing_doc)];
|
2012-06-04 20:34:24 -05:00
|
|
|
|
2013-07-22 11:49:04 -05:00
|
|
|
// Make extra accessible for benchmarking
|
|
|
|
#[cfg(test)] extern mod extra(vers="0.8-pre");
|
|
|
|
|
2013-06-17 01:21:49 -05:00
|
|
|
// Make std testable by not duplicating lang items. See #2912
|
2013-05-17 17:28:44 -05:00
|
|
|
#[cfg(test)] extern mod realstd(name = "std");
|
|
|
|
#[cfg(test)] pub use kinds = realstd::kinds;
|
|
|
|
#[cfg(test)] pub use ops = realstd::ops;
|
|
|
|
#[cfg(test)] pub use cmp = realstd::cmp;
|
2013-03-26 21:53:33 -05:00
|
|
|
|
2013-03-06 21:09:17 -06:00
|
|
|
// On Linux, link to the runtime with -lrt.
|
|
|
|
#[cfg(target_os = "linux")]
|
2013-03-13 21:12:43 -05:00
|
|
|
#[doc(hidden)]
|
2013-03-06 21:09:17 -06:00
|
|
|
pub mod linkhack {
|
|
|
|
#[link_args="-lrustrt -lrt"]
|
2013-03-08 18:05:50 -06:00
|
|
|
#[link_args = "-lpthread"]
|
2013-03-06 21:09:17 -06:00
|
|
|
extern {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-04-23 17:11:28 -05:00
|
|
|
// Internal macros
|
|
|
|
mod macros;
|
|
|
|
|
2013-01-08 21:37:25 -06:00
|
|
|
/* The Prelude. */
|
|
|
|
|
|
|
|
pub mod prelude;
|
2011-12-13 18:25:51 -06:00
|
|
|
|
2012-11-30 02:47:45 -06:00
|
|
|
/* Primitive types */
|
2012-04-14 19:21:10 -05:00
|
|
|
|
2013-05-12 20:14:40 -05:00
|
|
|
#[path = "num/int_macros.rs"] mod int_macros;
|
|
|
|
#[path = "num/uint_macros.rs"] mod uint_macros;
|
|
|
|
|
|
|
|
#[path = "num/int.rs"] pub mod int;
|
|
|
|
#[path = "num/i8.rs"] pub mod i8;
|
|
|
|
#[path = "num/i16.rs"] pub mod i16;
|
|
|
|
#[path = "num/i32.rs"] pub mod i32;
|
|
|
|
#[path = "num/i64.rs"] pub mod i64;
|
|
|
|
|
|
|
|
#[path = "num/uint.rs"] pub mod uint;
|
|
|
|
#[path = "num/u8.rs"] pub mod u8;
|
|
|
|
#[path = "num/u16.rs"] pub mod u16;
|
|
|
|
#[path = "num/u32.rs"] pub mod u32;
|
|
|
|
#[path = "num/u64.rs"] pub mod u64;
|
|
|
|
|
|
|
|
#[path = "num/float.rs"] pub mod float;
|
|
|
|
#[path = "num/f32.rs"] pub mod f32;
|
|
|
|
#[path = "num/f64.rs"] pub mod f64;
|
2012-11-30 02:47:45 -06:00
|
|
|
|
2012-12-03 19:28:19 -06:00
|
|
|
pub mod nil;
|
2012-10-03 21:24:06 -05:00
|
|
|
pub mod bool;
|
2012-11-30 02:47:45 -06:00
|
|
|
pub mod char;
|
2012-10-03 21:24:06 -05:00
|
|
|
pub mod tuple;
|
2012-11-30 02:47:45 -06:00
|
|
|
|
|
|
|
pub mod vec;
|
|
|
|
pub mod at_vec;
|
|
|
|
pub mod str;
|
|
|
|
|
2013-04-22 14:42:25 -05:00
|
|
|
#[path = "str/ascii.rs"]
|
|
|
|
pub mod ascii;
|
|
|
|
|
2012-11-30 02:47:45 -06:00
|
|
|
pub mod ptr;
|
2012-10-25 16:44:26 -05:00
|
|
|
pub mod owned;
|
2013-01-11 23:01:42 -06:00
|
|
|
pub mod managed;
|
2013-06-02 18:16:40 -05:00
|
|
|
pub mod borrow;
|
2011-12-13 18:25:51 -06:00
|
|
|
|
|
|
|
|
2012-11-30 02:47:45 -06:00
|
|
|
/* Core language traits */
|
|
|
|
|
2013-05-08 06:11:23 -05:00
|
|
|
#[cfg(not(test))] pub mod kinds;
|
|
|
|
#[cfg(not(test))] pub mod ops;
|
|
|
|
#[cfg(not(test))] pub mod cmp;
|
2012-11-30 02:47:45 -06:00
|
|
|
|
|
|
|
|
|
|
|
/* Common traits */
|
|
|
|
|
|
|
|
pub mod from_str;
|
2013-01-19 15:41:25 -06:00
|
|
|
#[path = "num/num.rs"]
|
2012-10-03 21:24:06 -05:00
|
|
|
pub mod num;
|
|
|
|
pub mod iter;
|
2013-04-09 09:54:32 -05:00
|
|
|
pub mod iterator;
|
2012-10-03 21:24:06 -05:00
|
|
|
pub mod to_str;
|
|
|
|
pub mod to_bytes;
|
2012-11-26 18:12:47 -06:00
|
|
|
pub mod clone;
|
2012-11-30 02:47:45 -06:00
|
|
|
pub mod io;
|
|
|
|
pub mod hash;
|
2013-01-20 12:46:06 -06:00
|
|
|
pub mod container;
|
2012-08-01 18:04:43 -05:00
|
|
|
|
|
|
|
|
2012-11-30 02:47:45 -06:00
|
|
|
/* Common data structures */
|
|
|
|
|
|
|
|
pub mod option;
|
|
|
|
pub mod result;
|
|
|
|
pub mod either;
|
2013-01-23 09:25:27 -06:00
|
|
|
pub mod hashmap;
|
2013-02-25 15:23:16 -06:00
|
|
|
pub mod cell;
|
2013-03-02 13:41:31 -06:00
|
|
|
pub mod trie;
|
2012-02-22 06:06:38 -06:00
|
|
|
|
2012-11-30 02:47:45 -06:00
|
|
|
|
|
|
|
/* Tasks and communication */
|
|
|
|
|
2012-11-28 14:33:00 -06:00
|
|
|
pub mod task;
|
2013-02-02 05:10:12 -06:00
|
|
|
pub mod comm;
|
2012-10-03 21:24:06 -05:00
|
|
|
pub mod pipes;
|
2013-05-08 08:02:21 -05:00
|
|
|
pub mod local_data;
|
2012-02-22 06:06:38 -06:00
|
|
|
|
2012-11-30 02:47:45 -06:00
|
|
|
|
|
|
|
/* Runtime and platform support */
|
2011-12-13 18:25:51 -06:00
|
|
|
|
2012-10-03 21:24:06 -05:00
|
|
|
pub mod libc;
|
|
|
|
pub mod os;
|
|
|
|
pub mod path;
|
|
|
|
pub mod rand;
|
|
|
|
pub mod run;
|
|
|
|
pub mod sys;
|
|
|
|
pub mod cast;
|
|
|
|
pub mod repr;
|
|
|
|
pub mod cleanup;
|
|
|
|
pub mod reflect;
|
2012-10-17 18:40:18 -05:00
|
|
|
pub mod condition;
|
2012-11-30 02:47:45 -06:00
|
|
|
pub mod logging;
|
|
|
|
pub mod util;
|
2011-12-13 18:25:51 -06:00
|
|
|
|
2012-11-30 02:47:45 -06:00
|
|
|
|
|
|
|
/* Unsupported interfaces */
|
|
|
|
|
|
|
|
// Private APIs
|
2013-02-27 21:53:31 -06:00
|
|
|
pub mod unstable;
|
2012-11-30 02:47:45 -06:00
|
|
|
|
|
|
|
/* For internal use, not exported */
|
|
|
|
|
2013-05-03 16:10:32 -05:00
|
|
|
mod unicode;
|
2013-01-19 15:41:25 -06:00
|
|
|
#[path = "num/cmath.rs"]
|
2013-05-03 16:10:32 -05:00
|
|
|
mod cmath;
|
2013-04-27 20:57:15 -05:00
|
|
|
|
|
|
|
// XXX: This shouldn't be pub, and it should be reexported under 'unstable'
|
|
|
|
// but name resolution doesn't work without it being pub.
|
|
|
|
pub mod rt;
|
2012-11-30 02:47:45 -06:00
|
|
|
|
2012-11-28 14:33:00 -06:00
|
|
|
// A curious inner-module that's not exported that contains the binding
|
2013-05-17 17:28:44 -05:00
|
|
|
// 'std' so that macro-expanded references to std::error and such
|
|
|
|
// can be resolved within libstd.
|
2013-03-13 21:12:55 -05:00
|
|
|
#[doc(hidden)]
|
2013-05-20 17:20:16 -05:00
|
|
|
mod std {
|
|
|
|
pub use clone;
|
|
|
|
pub use cmp;
|
|
|
|
pub use condition;
|
|
|
|
pub use option;
|
|
|
|
pub use kinds;
|
2013-07-14 03:43:31 -05:00
|
|
|
pub use local_data;
|
2013-05-20 17:20:16 -05:00
|
|
|
pub use sys;
|
|
|
|
pub use pipes;
|
2013-05-24 21:35:29 -05:00
|
|
|
pub use unstable;
|
|
|
|
pub use str;
|
|
|
|
pub use os;
|
2013-05-20 17:20:16 -05:00
|
|
|
}
|