mirror of
https://github.com/pezkuwichain/serde.git
synced 2026-04-25 10:27:56 +00:00
Compare commits
2 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| af31449cb1 | |||
| 1afae183b0 |
@@ -1,7 +1,6 @@
|
|||||||
[workspace]
|
[workspace]
|
||||||
members = [
|
members = [
|
||||||
"serde",
|
"serde",
|
||||||
"serde_derive",
|
|
||||||
"serde_derive_internals",
|
"serde_derive_internals",
|
||||||
"serde_test",
|
"serde_test",
|
||||||
"test_suite",
|
"test_suite",
|
||||||
|
|||||||
@@ -17,8 +17,7 @@ default = []
|
|||||||
deserialize_in_place = []
|
deserialize_in_place = []
|
||||||
|
|
||||||
[lib]
|
[lib]
|
||||||
name = "serde_derive"
|
crate-type = ["cdylib"]
|
||||||
proc-macro = true
|
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
proc-macro2 = "1.0"
|
proc-macro2 = "1.0"
|
||||||
@@ -30,3 +29,8 @@ serde = { version = "1.0", path = "../serde" }
|
|||||||
|
|
||||||
[package.metadata.docs.rs]
|
[package.metadata.docs.rs]
|
||||||
targets = ["x86_64-unknown-linux-gnu"]
|
targets = ["x86_64-unknown-linux-gnu"]
|
||||||
|
|
||||||
|
[workspace]
|
||||||
|
|
||||||
|
[patch.crates-io]
|
||||||
|
proc-macro2 = { git = "https://github.com/dtolnay/watt" }
|
||||||
|
|||||||
+18
-15
@@ -68,12 +68,11 @@ extern crate quote;
|
|||||||
#[macro_use]
|
#[macro_use]
|
||||||
extern crate syn;
|
extern crate syn;
|
||||||
|
|
||||||
extern crate proc_macro;
|
|
||||||
extern crate proc_macro2;
|
extern crate proc_macro2;
|
||||||
|
|
||||||
mod internals;
|
mod internals;
|
||||||
|
|
||||||
use proc_macro::TokenStream;
|
use proc_macro2::TokenStream;
|
||||||
use syn::DeriveInput;
|
use syn::DeriveInput;
|
||||||
|
|
||||||
#[macro_use]
|
#[macro_use]
|
||||||
@@ -87,23 +86,27 @@ mod pretend;
|
|||||||
mod ser;
|
mod ser;
|
||||||
mod try;
|
mod try;
|
||||||
|
|
||||||
#[proc_macro_derive(Serialize, attributes(serde))]
|
#[no_mangle]
|
||||||
pub fn derive_serialize(input: TokenStream) -> TokenStream {
|
pub extern "C" fn derive_serialize(input: TokenStream) -> TokenStream {
|
||||||
let mut input = parse_macro_input!(input as DeriveInput);
|
let mut input: DeriveInput = match syn::parse2(input) {
|
||||||
ser::expand_derive_serialize(&mut input)
|
Ok(input) => input,
|
||||||
.unwrap_or_else(to_compile_errors)
|
Err(err) => return err.to_compile_error(),
|
||||||
.into()
|
};
|
||||||
|
|
||||||
|
ser::expand_derive_serialize(&mut input).unwrap_or_else(to_compile_errors)
|
||||||
}
|
}
|
||||||
|
|
||||||
#[proc_macro_derive(Deserialize, attributes(serde))]
|
#[no_mangle]
|
||||||
pub fn derive_deserialize(input: TokenStream) -> TokenStream {
|
pub extern "C" fn derive_deserialize(input: TokenStream) -> TokenStream {
|
||||||
let mut input = parse_macro_input!(input as DeriveInput);
|
let mut input: DeriveInput = match syn::parse2(input) {
|
||||||
de::expand_derive_deserialize(&mut input)
|
Ok(input) => input,
|
||||||
.unwrap_or_else(to_compile_errors)
|
Err(err) => return err.to_compile_error(),
|
||||||
.into()
|
};
|
||||||
|
|
||||||
|
de::expand_derive_deserialize(&mut input).unwrap_or_else(to_compile_errors)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn to_compile_errors(errors: Vec<syn::Error>) -> proc_macro2::TokenStream {
|
fn to_compile_errors(errors: Vec<syn::Error>) -> TokenStream {
|
||||||
let compile_errors = errors.iter().map(syn::Error::to_compile_error);
|
let compile_errors = errors.iter().map(syn::Error::to_compile_error);
|
||||||
quote!(#(#compile_errors)*)
|
quote!(#(#compile_errors)*)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -21,7 +21,9 @@ fnv = "1.0"
|
|||||||
macrotest = "=1.0.9"
|
macrotest = "=1.0.9"
|
||||||
prettyplease = "=0.1.14"
|
prettyplease = "=0.1.14"
|
||||||
rustversion = "1.0"
|
rustversion = "1.0"
|
||||||
serde = { path = "../serde", features = ["rc", "derive"] }
|
serde = { path = "../serde", features = ["rc"] }
|
||||||
serde_derive = { path = "../serde_derive", features = ["deserialize_in_place"] }
|
wa-serde-derive = { path = "../wa-serde-derive" }
|
||||||
serde_test = { path = "../serde_test" }
|
serde_test = { path = "../serde_test" }
|
||||||
trybuild = { version = "1.0.49", features = ["diff"] }
|
trybuild = { version = "1.0.49", features = ["diff"] }
|
||||||
|
|
||||||
|
[workspace]
|
||||||
|
|||||||
@@ -1,3 +1,5 @@
|
|||||||
|
#![cfg(any())]
|
||||||
|
|
||||||
#[cfg_attr(target_os = "emscripten", ignore)]
|
#[cfg_attr(target_os = "emscripten", ignore)]
|
||||||
#[rustversion::attr(not(nightly), ignore)]
|
#[rustversion::attr(not(nightly), ignore)]
|
||||||
#[cfg_attr(miri, ignore)]
|
#[cfg_attr(miri, ignore)]
|
||||||
|
|||||||
@@ -11,6 +11,7 @@
|
|||||||
|
|
||||||
use serde::de::{self, MapAccess, Unexpected, Visitor};
|
use serde::de::{self, MapAccess, Unexpected, Visitor};
|
||||||
use serde::{Deserialize, Deserializer, Serialize, Serializer};
|
use serde::{Deserialize, Deserializer, Serialize, Serializer};
|
||||||
|
use serde_derive::{Deserialize, Serialize};
|
||||||
|
|
||||||
use std::collections::{BTreeMap, HashMap};
|
use std::collections::{BTreeMap, HashMap};
|
||||||
use std::convert::TryFrom;
|
use std::convert::TryFrom;
|
||||||
|
|||||||
@@ -5,6 +5,7 @@
|
|||||||
)]
|
)]
|
||||||
|
|
||||||
use serde::{Deserialize, Deserializer};
|
use serde::{Deserialize, Deserializer};
|
||||||
|
use serde_derive::Deserialize;
|
||||||
use serde_test::{assert_de_tokens, assert_de_tokens_error, Token};
|
use serde_test::{assert_de_tokens, assert_de_tokens_error, Token};
|
||||||
|
|
||||||
use std::borrow::Cow;
|
use std::borrow::Cow;
|
||||||
|
|||||||
@@ -34,6 +34,7 @@ use std::sync::atomic::{AtomicI64, AtomicU64};
|
|||||||
use fnv::FnvHasher;
|
use fnv::FnvHasher;
|
||||||
use serde::de::DeserializeOwned;
|
use serde::de::DeserializeOwned;
|
||||||
use serde::{Deserialize, Deserializer};
|
use serde::{Deserialize, Deserializer};
|
||||||
|
use serde_derive::Deserialize;
|
||||||
use serde_test::{assert_de_tokens, Configure, Token};
|
use serde_test::{assert_de_tokens, Configure, Token};
|
||||||
|
|
||||||
#[macro_use]
|
#[macro_use]
|
||||||
|
|||||||
@@ -7,6 +7,7 @@
|
|||||||
|
|
||||||
use serde::de::IntoDeserializer;
|
use serde::de::IntoDeserializer;
|
||||||
use serde::Deserialize;
|
use serde::Deserialize;
|
||||||
|
use serde_derive::Deserialize;
|
||||||
use serde_test::{assert_de_tokens_error, Token};
|
use serde_test::{assert_de_tokens_error, Token};
|
||||||
use std::collections::{BTreeMap, BTreeSet, HashMap, HashSet};
|
use std::collections::{BTreeMap, BTreeSet, HashMap, HashSet};
|
||||||
use std::ffi::{CStr, CString};
|
use std::ffi::{CStr, CString};
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
// successfully when there are a variety of generics and non-(de)serializable
|
// successfully when there are a variety of generics and non-(de)serializable
|
||||||
// types involved.
|
// types involved.
|
||||||
|
|
||||||
|
#![cfg(any())]
|
||||||
#![deny(warnings)]
|
#![deny(warnings)]
|
||||||
#![allow(
|
#![allow(
|
||||||
unknown_lints,
|
unknown_lints,
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
#![allow(clippy::derive_partial_eq_without_eq)]
|
#![allow(clippy::derive_partial_eq_without_eq)]
|
||||||
|
|
||||||
use serde::Deserialize;
|
use serde_derive::Deserialize;
|
||||||
use serde_test::{assert_de_tokens, Token};
|
use serde_test::{assert_de_tokens, Token};
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
|||||||
@@ -5,6 +5,7 @@ use serde::de::{
|
|||||||
DeserializeSeed, EnumAccess, IgnoredAny, IntoDeserializer, VariantAccess, Visitor,
|
DeserializeSeed, EnumAccess, IgnoredAny, IntoDeserializer, VariantAccess, Visitor,
|
||||||
};
|
};
|
||||||
use serde::{forward_to_deserialize_any, Deserialize, Deserializer};
|
use serde::{forward_to_deserialize_any, Deserialize, Deserializer};
|
||||||
|
use serde_derive::Deserialize;
|
||||||
|
|
||||||
#[derive(PartialEq, Debug, Deserialize)]
|
#[derive(PartialEq, Debug, Deserialize)]
|
||||||
enum Target {
|
enum Target {
|
||||||
|
|||||||
@@ -8,7 +8,7 @@
|
|||||||
|
|
||||||
mod bytes;
|
mod bytes;
|
||||||
|
|
||||||
use serde::{Deserialize, Serialize};
|
use serde_derive::{Deserialize, Serialize};
|
||||||
use serde_test::{
|
use serde_test::{
|
||||||
assert_de_tokens, assert_de_tokens_error, assert_ser_tokens, assert_tokens, Token,
|
assert_de_tokens, assert_de_tokens_error, assert_ser_tokens, assert_tokens, Token,
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
#![allow(clippy::redundant_field_names)]
|
#![allow(clippy::redundant_field_names)]
|
||||||
|
|
||||||
use serde::{Deserialize, Serialize};
|
use serde_derive::{Deserialize, Serialize};
|
||||||
|
|
||||||
mod remote {
|
mod remote {
|
||||||
pub struct Unit;
|
pub struct Unit;
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
#![allow(clippy::used_underscore_binding)]
|
#![allow(clippy::used_underscore_binding)]
|
||||||
|
|
||||||
use serde::{Deserialize, Serialize};
|
use serde_derive::{Deserialize, Serialize};
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_self() {
|
fn test_self() {
|
||||||
|
|||||||
@@ -22,7 +22,7 @@ use std::str;
|
|||||||
use std::sync::atomic::{AtomicI64, AtomicU64};
|
use std::sync::atomic::{AtomicI64, AtomicU64};
|
||||||
|
|
||||||
use fnv::FnvHasher;
|
use fnv::FnvHasher;
|
||||||
use serde::Serialize;
|
use serde_derive::Serialize;
|
||||||
use serde_test::{assert_ser_tokens, assert_ser_tokens_error, Configure, Token};
|
use serde_test::{assert_ser_tokens, assert_ser_tokens_error, Configure, Token};
|
||||||
|
|
||||||
#[macro_use]
|
#[macro_use]
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_gen_custom_serde() {
|
fn test_gen_custom_serde() {
|
||||||
#[derive(serde::Serialize, serde::Deserialize)]
|
#[derive(serde_derive::Serialize, serde_derive::Deserialize)]
|
||||||
#[serde(crate = "fake_serde")]
|
#[serde(crate = "fake_serde")]
|
||||||
struct Foo;
|
struct Foo;
|
||||||
|
|
||||||
|
|||||||
@@ -3,6 +3,7 @@
|
|||||||
use serde::de::value::{self, MapAccessDeserializer};
|
use serde::de::value::{self, MapAccessDeserializer};
|
||||||
use serde::de::{IntoDeserializer, MapAccess, Visitor};
|
use serde::de::{IntoDeserializer, MapAccess, Visitor};
|
||||||
use serde::{Deserialize, Deserializer};
|
use serde::{Deserialize, Deserializer};
|
||||||
|
use serde_derive::Deserialize;
|
||||||
use serde_test::{assert_de_tokens, Token};
|
use serde_test::{assert_de_tokens, Token};
|
||||||
use std::fmt;
|
use std::fmt;
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1 @@
|
|||||||
|
*.wasm
|
||||||
@@ -0,0 +1,17 @@
|
|||||||
|
[package]
|
||||||
|
name = "wa-serde-derive"
|
||||||
|
version = "0.1.137"
|
||||||
|
authors = ["David Tolnay <dtolnay@gmail.com>"]
|
||||||
|
license = "MIT OR Apache-2.0"
|
||||||
|
description = "serde_derive compiled to wasm"
|
||||||
|
repository = "https://github.com/dtolnay/watt"
|
||||||
|
include = ["src"]
|
||||||
|
|
||||||
|
[lib]
|
||||||
|
name = "serde_derive"
|
||||||
|
proc-macro = true
|
||||||
|
|
||||||
|
[dependencies]
|
||||||
|
watt = "0.4"
|
||||||
|
|
||||||
|
[workspace]
|
||||||
@@ -0,0 +1,18 @@
|
|||||||
|
extern crate proc_macro;
|
||||||
|
extern crate watt;
|
||||||
|
|
||||||
|
use proc_macro::TokenStream;
|
||||||
|
use watt::WasmMacro;
|
||||||
|
|
||||||
|
static MACRO: WasmMacro = WasmMacro::new(WASM);
|
||||||
|
static WASM: &[u8] = include_bytes!("serde_derive.wasm");
|
||||||
|
|
||||||
|
#[proc_macro_derive(Serialize, attributes(serde))]
|
||||||
|
pub fn derive_serialize(input: TokenStream) -> TokenStream {
|
||||||
|
MACRO.proc_macro_derive("derive_serialize", input)
|
||||||
|
}
|
||||||
|
|
||||||
|
#[proc_macro_derive(Deserialize, attributes(serde))]
|
||||||
|
pub fn derive_deserialize(input: TokenStream) -> TokenStream {
|
||||||
|
MACRO.proc_macro_derive("derive_deserialize", input)
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user