0c820d4123
This only changes the directory names; it does not change the "real" metadata names.
54 lines
1.6 KiB
Rust
54 lines
1.6 KiB
Rust
// 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 <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.
|
|
|
|
/*!
|
|
The kind traits
|
|
|
|
Rust types can be classified in various useful ways according to
|
|
intrinsic properties of the type. These classifications, often called
|
|
'kinds', are represented as traits.
|
|
|
|
They cannot be implemented by user code, but are instead implemented
|
|
by the compiler automatically for the types to which they apply.
|
|
|
|
The 4 kinds are
|
|
|
|
* Copy - types that may be copied without allocation. This includes
|
|
scalar types and managed pointers, and exludes owned pointers. It
|
|
also excludes types that implement `Drop`.
|
|
|
|
* Owned - owned types and types containing owned types. These types
|
|
may be transferred across task boundaries.
|
|
|
|
* Const - types that are deeply immutable. Const types are used for
|
|
freezable data structures.
|
|
|
|
`Copy` types include both implicitly copyable types that the compiler
|
|
will copy automatically and non-implicitly copyable types that require
|
|
the `copy` keyword to copy. Types that do not implement `Copy` may
|
|
instead implement `Clone`.
|
|
|
|
*/
|
|
|
|
#[lang="copy"]
|
|
pub trait Copy {
|
|
// Empty.
|
|
}
|
|
|
|
#[lang="owned"]
|
|
pub trait Owned {
|
|
// Empty.
|
|
}
|
|
|
|
#[lang="const"]
|
|
pub trait Const {
|
|
// Empty.
|
|
}
|