2013-02-28 13:15:32 +00:00
|
|
|
// Copyright 2012-2013 The Rust Project Developers. See the COPYRIGHT
|
2012-12-03 16:48:01 -08: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 16:52:32 -07:00
|
|
|
/*!
|
|
|
|
|
2013-03-24 18:38:17 -07:00
|
|
|
# The Rust core library
|
2012-09-19 16:52:32 -07:00
|
|
|
|
|
|
|
The Rust core library provides runtime features required by the language,
|
|
|
|
including the task scheduler and memory allocators, as well as library
|
|
|
|
support for Rust built-in types, platform abstractions, and other commonly
|
|
|
|
used features.
|
|
|
|
|
|
|
|
`core` includes modules corresponding to each of the integer types, each of
|
2013-03-24 18:38:17 -07:00
|
|
|
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`). Additionally, `core` 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 16:52:32 -07:00
|
|
|
|
2013-03-24 18:38:17 -07:00
|
|
|
# Core injection and the Rust prelude
|
|
|
|
|
|
|
|
`core` is imported at the topmost level of every crate by default, as
|
|
|
|
if the first line of each crate was
|
2012-09-19 16:52:32 -07:00
|
|
|
|
|
|
|
extern mod core;
|
2013-03-24 18:38:17 -07:00
|
|
|
|
|
|
|
This means that the contents of core can be accessed from from any context
|
|
|
|
with the `core::` path prefix, as in `use core::vec`, `use core::task::spawn`,
|
|
|
|
etc.
|
|
|
|
|
|
|
|
Additionally, `core` contains a `prelude` module that reexports many of the
|
|
|
|
most common core modules, types and traits. The contents of the prelude are
|
2013-04-01 12:11:07 -07:00
|
|
|
imported into every *module* by default. Implicitly, all modules behave as if
|
2013-03-24 18:38:17 -07:00
|
|
|
they contained the following prologue:
|
|
|
|
|
|
|
|
use core::prelude::*;
|
2012-09-19 16:52:32 -07:00
|
|
|
|
|
|
|
*/
|
|
|
|
|
2012-11-30 00:47:45 -08:00
|
|
|
|
2011-12-05 16:46:37 -08:00
|
|
|
#[link(name = "core",
|
2013-04-04 21:46:37 -07:00
|
|
|
vers = "0.7-pre",
|
2011-12-05 16:46:37 -08:00
|
|
|
uuid = "c70c24a7-5551-4f73-8e37-380b11d80be8",
|
2012-03-28 13:42:17 -07:00
|
|
|
url = "https://github.com/mozilla/rust/tree/master/src/libcore")];
|
2011-12-05 16:46:37 -08:00
|
|
|
|
|
|
|
#[comment = "The Rust core library"];
|
2013-03-01 08:41:31 -08:00
|
|
|
#[license = "MIT/ASL2"];
|
2011-12-08 21:08:23 -08:00
|
|
|
#[crate_type = "lib"];
|
2011-12-05 16:46:37 -08:00
|
|
|
|
2012-11-30 00:47:45 -08:00
|
|
|
|
2012-04-19 01:00:52 -07:00
|
|
|
// Don't link to core. We are core.
|
|
|
|
#[no_core];
|
|
|
|
|
2012-09-09 14:51:56 -07:00
|
|
|
#[deny(non_camel_case_types)];
|
2012-06-04 18:34:24 -07:00
|
|
|
|
2013-03-26 19:53:33 -07:00
|
|
|
// Make core testable by not duplicating lang items. See #2912
|
2013-04-04 21:46:37 -07:00
|
|
|
#[cfg(test)] extern mod realcore(name = "core", vers = "0.7-pre");
|
2013-03-26 19:53:33 -07:00
|
|
|
#[cfg(test)] pub use kinds = realcore::kinds;
|
|
|
|
#[cfg(test)] pub use ops = realcore::ops;
|
|
|
|
#[cfg(test)] pub use cmp = realcore::cmp;
|
|
|
|
|
|
|
|
/* Reexported core operators */
|
|
|
|
|
2013-05-07 17:50:42 -07:00
|
|
|
pub use kinds::{Const, Copy, Owned};
|
2013-03-26 19:53:33 -07:00
|
|
|
pub use ops::{Drop};
|
2013-05-01 15:40:05 +10:00
|
|
|
pub use ops::{Add, Sub, Mul, Div, Rem, Neg, Not};
|
2013-03-26 19:53:33 -07:00
|
|
|
pub use ops::{BitAnd, BitOr, BitXor};
|
|
|
|
pub use ops::{Shl, Shr, Index};
|
|
|
|
|
|
|
|
|
|
|
|
/* Reexported types and traits */
|
|
|
|
|
|
|
|
pub use option::{Option, Some, None};
|
|
|
|
pub use result::{Result, Ok, Err};
|
|
|
|
|
|
|
|
pub use path::Path;
|
|
|
|
pub use path::GenericPath;
|
|
|
|
pub use path::WindowsPath;
|
|
|
|
pub use path::PosixPath;
|
|
|
|
|
|
|
|
pub use tuple::{CopyableTuple, ImmutableTuple, ExtendedTupleOps};
|
|
|
|
pub use str::{StrSlice};
|
|
|
|
pub use container::{Container, Mutable};
|
|
|
|
pub use vec::{CopyableVector, ImmutableVector};
|
|
|
|
pub use vec::{ImmutableEqVector, ImmutableCopyableVector};
|
2013-04-18 15:53:29 -07:00
|
|
|
pub use vec::{OwnedVector, OwnedCopyableVector, MutableVector};
|
2013-04-24 20:35:49 -04:00
|
|
|
pub use old_iter::{BaseIter, ExtendedIter, EqIter, CopyableIter};
|
|
|
|
pub use old_iter::{CopyableOrderedIter, CopyableNonstrictIter};
|
|
|
|
pub use old_iter::{ExtendedMutableIter};
|
|
|
|
pub use iter::Times;
|
2013-03-26 19:53:33 -07:00
|
|
|
|
2013-04-24 22:45:57 +10:00
|
|
|
pub use num::{Num, NumCast};
|
2013-04-29 15:33:55 +10:00
|
|
|
pub use num::{Orderable, Signed, Unsigned, Round};
|
2013-04-29 23:38:58 +10:00
|
|
|
pub use num::{Algebraic, Trigonometric, Exponential, Hyperbolic};
|
2013-04-29 15:33:55 +10:00
|
|
|
pub use num::{Integer, Fractional, Real, RealExt};
|
2013-04-26 16:27:51 +10:00
|
|
|
pub use num::{Bitwise, BitCount, Bounded};
|
2013-04-26 19:56:11 +10:00
|
|
|
pub use num::{Primitive, Int, Float};
|
2013-04-27 01:01:53 +10:00
|
|
|
|
2013-03-26 19:53:33 -07:00
|
|
|
pub use ptr::Ptr;
|
2013-05-02 20:20:22 +09:00
|
|
|
pub use from_str::FromStr;
|
2013-03-26 19:53:33 -07:00
|
|
|
pub use to_str::ToStr;
|
|
|
|
pub use clone::Clone;
|
|
|
|
|
2013-03-06 19:09:17 -08:00
|
|
|
// On Linux, link to the runtime with -lrt.
|
|
|
|
#[cfg(target_os = "linux")]
|
2013-03-13 22:12:43 -04:00
|
|
|
#[doc(hidden)]
|
2013-03-06 19:09:17 -08:00
|
|
|
pub mod linkhack {
|
|
|
|
#[link_args="-lrustrt -lrt"]
|
2013-03-08 16:05:50 -08:00
|
|
|
#[link_args = "-lpthread"]
|
2013-03-06 19:09:17 -08:00
|
|
|
extern {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-04-23 15:11:28 -07:00
|
|
|
// Internal macros
|
|
|
|
mod macros;
|
|
|
|
|
2013-01-08 19:37:25 -08:00
|
|
|
/* The Prelude. */
|
|
|
|
|
|
|
|
pub mod prelude;
|
2011-12-13 16:25:51 -08:00
|
|
|
|
2012-11-30 00:47:45 -08:00
|
|
|
/* Primitive types */
|
2012-04-14 17:21:10 -07:00
|
|
|
|
2013-01-19 22:41:25 +01:00
|
|
|
#[path = "num/int-template.rs"] #[merge = "num/int-template/int.rs"]
|
2012-11-30 00:47:45 -08:00
|
|
|
pub mod int;
|
2013-01-19 22:41:25 +01:00
|
|
|
#[path = "num/int-template.rs"] #[merge = "num/int-template/i8.rs"]
|
2012-11-28 12:33:00 -08:00
|
|
|
pub mod i8;
|
2013-01-19 22:41:25 +01:00
|
|
|
#[path = "num/int-template.rs"] #[merge = "num/int-template/i16.rs"]
|
2012-11-28 12:33:00 -08:00
|
|
|
pub mod i16;
|
2013-01-19 22:41:25 +01:00
|
|
|
#[path = "num/int-template.rs"] #[merge = "num/int-template/i32.rs"]
|
2012-11-28 12:33:00 -08:00
|
|
|
pub mod i32;
|
2013-01-19 22:41:25 +01:00
|
|
|
#[path = "num/int-template.rs"] #[merge = "num/int-template/i64.rs"]
|
2012-11-28 12:33:00 -08:00
|
|
|
pub mod i64;
|
2013-01-19 22:41:25 +01:00
|
|
|
#[path = "num/uint-template.rs"] #[merge = "num/uint-template/uint.rs"]
|
2012-11-28 12:33:00 -08:00
|
|
|
pub mod uint;
|
2012-04-14 22:07:45 -07:00
|
|
|
|
2013-01-19 22:41:25 +01:00
|
|
|
#[path = "num/uint-template.rs"] #[merge = "num/uint-template/u8.rs"]
|
2012-11-28 12:33:00 -08:00
|
|
|
pub mod u8;
|
2013-01-19 22:41:25 +01:00
|
|
|
#[path = "num/uint-template.rs"] #[merge = "num/uint-template/u16.rs"]
|
2012-11-28 12:33:00 -08:00
|
|
|
pub mod u16;
|
2013-01-19 22:41:25 +01:00
|
|
|
#[path = "num/uint-template.rs"] #[merge = "num/uint-template/u32.rs"]
|
2012-11-28 12:33:00 -08:00
|
|
|
pub mod u32;
|
2013-01-19 22:41:25 +01:00
|
|
|
#[path = "num/uint-template.rs"] #[merge = "num/uint-template/u64.rs"]
|
2012-11-28 12:33:00 -08:00
|
|
|
pub mod u64;
|
2012-04-14 22:07:45 -07:00
|
|
|
|
2013-01-19 22:41:25 +01:00
|
|
|
#[path = "num/float.rs"]
|
2012-10-03 19:24:06 -07:00
|
|
|
pub mod float;
|
2013-01-19 22:41:25 +01:00
|
|
|
#[path = "num/f32.rs"]
|
2012-10-03 19:24:06 -07:00
|
|
|
pub mod f32;
|
2013-01-19 22:41:25 +01:00
|
|
|
#[path = "num/f64.rs"]
|
2012-10-03 19:24:06 -07:00
|
|
|
pub mod f64;
|
2012-11-30 00:47:45 -08:00
|
|
|
|
2012-12-03 17:28:19 -08:00
|
|
|
pub mod nil;
|
2012-10-03 19:24:06 -07:00
|
|
|
pub mod bool;
|
2012-11-30 00:47:45 -08:00
|
|
|
pub mod char;
|
2012-10-03 19:24:06 -07:00
|
|
|
pub mod tuple;
|
2012-11-30 00:47:45 -08:00
|
|
|
|
|
|
|
pub mod vec;
|
|
|
|
pub mod at_vec;
|
|
|
|
pub mod str;
|
|
|
|
|
2013-04-22 21:42:25 +02:00
|
|
|
#[path = "str/ascii.rs"]
|
|
|
|
pub mod ascii;
|
|
|
|
|
2012-11-30 00:47:45 -08:00
|
|
|
pub mod ptr;
|
2012-10-25 14:44:26 -07:00
|
|
|
pub mod owned;
|
2013-01-11 21:01:42 -08:00
|
|
|
pub mod managed;
|
2011-12-13 16:25:51 -08:00
|
|
|
|
|
|
|
|
2012-11-30 00:47:45 -08:00
|
|
|
/* Core language traits */
|
|
|
|
|
2013-05-08 21:11:23 +10:00
|
|
|
#[cfg(not(test))] pub mod kinds;
|
|
|
|
#[cfg(not(test))] pub mod ops;
|
|
|
|
#[cfg(not(test))] pub mod cmp;
|
2012-11-30 00:47:45 -08:00
|
|
|
|
|
|
|
|
|
|
|
/* Common traits */
|
|
|
|
|
|
|
|
pub mod from_str;
|
2013-01-19 22:41:25 +01:00
|
|
|
#[path = "num/num.rs"]
|
2012-10-03 19:24:06 -07:00
|
|
|
pub mod num;
|
|
|
|
pub mod iter;
|
2013-04-24 20:35:49 -04:00
|
|
|
pub mod old_iter;
|
2013-04-09 10:54:32 -04:00
|
|
|
pub mod iterator;
|
2012-10-03 19:24:06 -07:00
|
|
|
pub mod to_str;
|
|
|
|
pub mod to_bytes;
|
2012-11-26 16:12:47 -08:00
|
|
|
pub mod clone;
|
2012-11-30 00:47:45 -08:00
|
|
|
pub mod io;
|
|
|
|
pub mod hash;
|
2013-01-20 13:46:06 -05:00
|
|
|
pub mod container;
|
2012-08-01 19:04:43 -04:00
|
|
|
|
|
|
|
|
2012-11-30 00:47:45 -08:00
|
|
|
/* Common data structures */
|
|
|
|
|
|
|
|
pub mod option;
|
|
|
|
pub mod result;
|
|
|
|
pub mod either;
|
2013-01-23 10:25:27 -05:00
|
|
|
pub mod hashmap;
|
2013-02-25 13:23:16 -08:00
|
|
|
pub mod cell;
|
2013-03-02 14:41:31 -05:00
|
|
|
pub mod trie;
|
2012-02-22 13:06:38 +01:00
|
|
|
|
2012-11-30 00:47:45 -08:00
|
|
|
|
|
|
|
/* Tasks and communication */
|
|
|
|
|
2012-11-28 16:20:41 -08:00
|
|
|
#[path = "task/mod.rs"]
|
2012-11-28 12:33:00 -08:00
|
|
|
pub mod task;
|
2013-02-02 03:10:12 -08:00
|
|
|
pub mod comm;
|
2012-10-03 19:24:06 -07:00
|
|
|
pub mod pipes;
|
2013-05-08 22:02:21 +09:00
|
|
|
pub mod local_data;
|
2012-02-22 13:06:38 +01:00
|
|
|
|
2012-11-30 00:47:45 -08:00
|
|
|
|
|
|
|
/* Runtime and platform support */
|
2011-12-13 16:25:51 -08:00
|
|
|
|
2012-10-03 19:24:06 -07:00
|
|
|
pub mod gc;
|
|
|
|
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 16:40:18 -07:00
|
|
|
pub mod condition;
|
2012-11-30 00:47:45 -08:00
|
|
|
pub mod logging;
|
|
|
|
pub mod util;
|
2011-12-13 16:25:51 -08:00
|
|
|
|
2012-11-30 00:47:45 -08:00
|
|
|
|
|
|
|
/* Unsupported interfaces */
|
|
|
|
|
|
|
|
// Private APIs
|
2013-02-27 19:53:31 -08:00
|
|
|
pub mod unstable;
|
2012-11-30 00:47:45 -08:00
|
|
|
|
|
|
|
/* For internal use, not exported */
|
|
|
|
|
2013-05-03 17:10:32 -04:00
|
|
|
mod unicode;
|
2013-01-19 22:41:25 +01:00
|
|
|
#[path = "num/cmath.rs"]
|
2013-05-03 17:10:32 -04:00
|
|
|
mod cmath;
|
|
|
|
mod stackwalk;
|
2013-02-03 18:15:43 -08:00
|
|
|
#[path = "rt/mod.rs"]
|
2013-05-03 17:10:32 -04:00
|
|
|
mod rt;
|
2012-11-30 00:47:45 -08:00
|
|
|
|
2012-11-28 12:33:00 -08:00
|
|
|
// A curious inner-module that's not exported that contains the binding
|
|
|
|
// 'core' so that macro-expanded references to core::error and such
|
|
|
|
// can be resolved within libcore.
|
2013-03-13 22:12:55 -04:00
|
|
|
#[doc(hidden)]
|
2013-03-26 19:53:33 -07:00
|
|
|
mod core {
|
2013-03-22 15:33:53 -04:00
|
|
|
pub use clone;
|
2012-12-11 15:16:36 -08:00
|
|
|
pub use cmp;
|
2012-12-14 11:52:11 -08:00
|
|
|
pub use condition;
|
2013-03-01 10:44:43 -08:00
|
|
|
pub use option;
|
2013-03-01 12:11:07 -08:00
|
|
|
pub use kinds;
|
2013-01-31 17:51:01 -08:00
|
|
|
pub use sys;
|
2013-02-02 03:10:12 -08:00
|
|
|
pub use pipes;
|
2012-11-28 12:33:00 -08:00
|
|
|
}
|