a76a802768
This commit completes the deprecation story for the in-tree serialization library. The compiler will now emit a warning whenever it encounters `deriving(Encodable)` or `deriving(Decodable)`, and the library itself is now marked `#[unstable]` for when feature staging is enabled. All users of serialization can migrate to the `rustc-serialize` crate on crates.io which provides the exact same interface as the libserialize library in-tree. The new deriving modes are named `RustcEncodable` and `RustcDecodable` and require `extern crate "rustc-serialize" as rustc_serialize` at the crate root in order to expand correctly. To migrate all crates, add the following to your `Cargo.toml`: [dependencies] rustc-serialize = "0.1.1" And then add the following to your crate root: extern crate "rustc-serialize" as rustc_serialize; Finally, rename `Encodable` and `Decodable` deriving modes to `RustcEncodable` and `RustcDecodable`. [breaking-change]
167 lines
3.8 KiB
Rust
167 lines
3.8 KiB
Rust
// Copyright 2012-2014 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.
|
|
|
|
pub use self::Os::*;
|
|
pub use self::Abi::*;
|
|
pub use self::Architecture::*;
|
|
pub use self::AbiArchitecture::*;
|
|
|
|
use std::fmt;
|
|
|
|
#[deriving(Copy, PartialEq)]
|
|
pub enum Os {
|
|
OsWindows,
|
|
OsMacos,
|
|
OsLinux,
|
|
OsAndroid,
|
|
OsFreebsd,
|
|
OsiOS,
|
|
OsDragonfly,
|
|
}
|
|
|
|
#[deriving(PartialEq, Eq, Hash, RustcEncodable, RustcDecodable, Clone, Copy)]
|
|
pub enum Abi {
|
|
// NB: This ordering MUST match the AbiDatas array below.
|
|
// (This is ensured by the test indices_are_correct().)
|
|
|
|
// Single platform ABIs come first (`for_arch()` relies on this)
|
|
Cdecl,
|
|
Stdcall,
|
|
Fastcall,
|
|
Aapcs,
|
|
Win64,
|
|
|
|
// Multiplatform ABIs second
|
|
Rust,
|
|
C,
|
|
System,
|
|
RustIntrinsic,
|
|
RustCall,
|
|
}
|
|
|
|
#[allow(non_camel_case_types)]
|
|
#[deriving(Copy, PartialEq)]
|
|
pub enum Architecture {
|
|
X86,
|
|
X86_64,
|
|
Arm,
|
|
Mips,
|
|
Mipsel
|
|
}
|
|
|
|
#[deriving(Copy)]
|
|
pub struct AbiData {
|
|
abi: Abi,
|
|
|
|
// Name of this ABI as we like it called.
|
|
name: &'static str,
|
|
}
|
|
|
|
#[deriving(Copy)]
|
|
pub enum AbiArchitecture {
|
|
/// Not a real ABI (e.g., intrinsic)
|
|
RustArch,
|
|
/// An ABI that specifies cross-platform defaults (e.g., "C")
|
|
AllArch,
|
|
/// Multiple architectures (bitset)
|
|
Archs(u32)
|
|
}
|
|
|
|
#[allow(non_upper_case_globals)]
|
|
static AbiDatas: &'static [AbiData] = &[
|
|
// Platform-specific ABIs
|
|
AbiData {abi: Cdecl, name: "cdecl" },
|
|
AbiData {abi: Stdcall, name: "stdcall" },
|
|
AbiData {abi: Fastcall, name:"fastcall" },
|
|
AbiData {abi: Aapcs, name: "aapcs" },
|
|
AbiData {abi: Win64, name: "win64" },
|
|
|
|
// Cross-platform ABIs
|
|
//
|
|
// NB: Do not adjust this ordering without
|
|
// adjusting the indices below.
|
|
AbiData {abi: Rust, name: "Rust" },
|
|
AbiData {abi: C, name: "C" },
|
|
AbiData {abi: System, name: "system" },
|
|
AbiData {abi: RustIntrinsic, name: "rust-intrinsic" },
|
|
AbiData {abi: RustCall, name: "rust-call" },
|
|
];
|
|
|
|
/// Returns the ABI with the given name (if any).
|
|
pub fn lookup(name: &str) -> Option<Abi> {
|
|
AbiDatas.iter().find(|abi_data| name == abi_data.name).map(|&x| x.abi)
|
|
}
|
|
|
|
pub fn all_names() -> Vec<&'static str> {
|
|
AbiDatas.iter().map(|d| d.name).collect()
|
|
}
|
|
|
|
impl Abi {
|
|
#[inline]
|
|
pub fn index(&self) -> uint {
|
|
*self as uint
|
|
}
|
|
|
|
#[inline]
|
|
pub fn data(&self) -> &'static AbiData {
|
|
&AbiDatas[self.index()]
|
|
}
|
|
|
|
pub fn name(&self) -> &'static str {
|
|
self.data().name
|
|
}
|
|
}
|
|
|
|
impl fmt::Show for Abi {
|
|
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
|
write!(f, "\"{}\"", self.name())
|
|
}
|
|
}
|
|
|
|
impl fmt::Show for Os {
|
|
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
|
match *self {
|
|
OsLinux => "linux".fmt(f),
|
|
OsWindows => "windows".fmt(f),
|
|
OsMacos => "macos".fmt(f),
|
|
OsiOS => "ios".fmt(f),
|
|
OsAndroid => "android".fmt(f),
|
|
OsFreebsd => "freebsd".fmt(f),
|
|
OsDragonfly => "dragonfly".fmt(f)
|
|
}
|
|
}
|
|
}
|
|
|
|
#[allow(non_snake_case)]
|
|
#[test]
|
|
fn lookup_Rust() {
|
|
let abi = lookup("Rust");
|
|
assert!(abi.is_some() && abi.unwrap().data().name == "Rust");
|
|
}
|
|
|
|
#[test]
|
|
fn lookup_cdecl() {
|
|
let abi = lookup("cdecl");
|
|
assert!(abi.is_some() && abi.unwrap().data().name == "cdecl");
|
|
}
|
|
|
|
#[test]
|
|
fn lookup_baz() {
|
|
let abi = lookup("baz");
|
|
assert!(abi.is_none());
|
|
}
|
|
|
|
#[test]
|
|
fn indices_are_correct() {
|
|
for (i, abi_data) in AbiDatas.iter().enumerate() {
|
|
assert_eq!(i, abi_data.abi.index());
|
|
}
|
|
}
|