aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndroid Build Coastguard Worker <android-build-coastguard-worker@google.com>2022-05-17 07:33:31 +0000
committerAndroid Build Coastguard Worker <android-build-coastguard-worker@google.com>2022-05-17 07:33:31 +0000
commitdda352945eb859600ef28722db3b64e4b134441d (patch)
tree655a665689a70f3e6239f18b0a779ba805315804
parentcfc7d1dc1fc3c6a5269340e2169efee176549f4d (diff)
parent83f451532a49a159d07a045a0d1c131e456e51bd (diff)
downloadproc-macro2-dda352945eb859600ef28722db3b64e4b134441d.tar.gz
Snap for 8603585 from 83f451532a49a159d07a045a0d1c131e456e51bd to mainline-tzdata3-release
Change-Id: Idb7a25880d6245a19b5a8e5f5a6f83ab24aa6f5d
-rw-r--r--.cargo_vcs_info.json7
-rw-r--r--.github/workflows/ci.yml39
-rw-r--r--Android.bp84
-rw-r--r--Cargo.toml17
-rw-r--r--Cargo.toml.orig8
-rw-r--r--METADATA8
-rw-r--r--README.md7
-rw-r--r--TEST_MAPPING157
-rw-r--r--build.rs68
-rw-r--r--cargo2android.json6
-rw-r--r--src/detection.rs18
-rw-r--r--src/fallback.rs108
-rw-r--r--src/lib.rs107
-rw-r--r--src/parse.rs19
-rw-r--r--src/wrapper.rs89
-rw-r--r--tests/comments.rs18
-rw-r--r--tests/marker.rs12
-rw-r--r--tests/test.rs27
-rw-r--r--tests/test_fmt.rs4
19 files changed, 496 insertions, 307 deletions
diff --git a/.cargo_vcs_info.json b/.cargo_vcs_info.json
index 1eb63e4..59bd97e 100644
--- a/.cargo_vcs_info.json
+++ b/.cargo_vcs_info.json
@@ -1,5 +1,6 @@
{
"git": {
- "sha1": "56043a1715cf9c458e5203bdf792668e3b271651"
- }
-}
+ "sha1": "7ecea3b88fe72672ca4270631b5d4585c0f7c715"
+ },
+ "path_in_vcs": ""
+} \ No newline at end of file
diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml
index e469b08..2063a5c 100644
--- a/.github/workflows/ci.yml
+++ b/.github/workflows/ci.yml
@@ -7,7 +7,7 @@ on:
jobs:
test:
- name: Rust ${{ matrix.rust }}
+ name: Rust ${{matrix.rust}}
runs-on: ubuntu-latest
strategy:
fail-fast: false
@@ -15,11 +15,9 @@ jobs:
rust: [1.31.0, stable, beta]
steps:
- uses: actions/checkout@v2
- - uses: actions-rs/toolchain@v1
+ - uses: dtolnay/rust-toolchain@master
with:
- toolchain: ${{ matrix.rust }}
- profile: minimal
- override: true
+ toolchain: ${{matrix.rust}}
- run: cargo test
- run: cargo test --no-default-features
- run: cargo test --features span-locations
@@ -31,11 +29,7 @@ jobs:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- - uses: actions-rs/toolchain@v1
- with:
- toolchain: nightly
- profile: minimal
- override: true
+ - uses: dtolnay/rust-toolchain@nightly
- run: cargo test
- run: cargo test --no-default-features
- run: cargo test --no-default-features -- --ignored # run the ignored test to make sure the `proc-macro` feature is disabled
@@ -51,23 +45,26 @@ jobs:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- - uses: actions-rs/toolchain@v1
+ - uses: dtolnay/rust-toolchain@nightly
with:
- toolchain: nightly
target: wasm32-unknown-unknown
- profile: minimal
- override: true
- run: cargo test --target wasm32-unknown-unknown --no-run
clippy:
name: Clippy
runs-on: ubuntu-latest
+ if: github.event_name != 'pull_request'
steps:
- uses: actions/checkout@v2
- - uses: actions-rs/toolchain@v1
- with:
- toolchain: nightly
- profile: minimal
- override: true
- components: clippy
- - run: cargo clippy -- -Dclippy::all
+ - uses: dtolnay/rust-toolchain@clippy
+ - run: cargo clippy --tests -- -Dclippy::all -Dclippy::pedantic
+ - run: cargo clippy --tests --all-features -- -Dclippy::all -Dclippy::pedantic
+
+ outdated:
+ name: Outdated
+ runs-on: ubuntu-latest
+ if: github.event_name != 'pull_request'
+ steps:
+ - uses: actions/checkout@v2
+ - uses: dtolnay/install@cargo-outdated
+ - run: cargo outdated --exit-code 1
diff --git a/Android.bp b/Android.bp
index 4c28943..410a4f4 100644
--- a/Android.bp
+++ b/Android.bp
@@ -1,4 +1,4 @@
-// This file is generated by cargo2android.py --run --dependencies --tests --host-first-multilib --features=default,span-locations.
+// This file is generated by cargo2android.py --config cargo2android.json.
// Do not modify this file as changes will be overridden on upgrade.
package {
@@ -40,6 +40,8 @@ license {
rust_library_host {
name: "libproc_macro2",
crate_name: "proc_macro2",
+ cargo_env_compat: true,
+ cargo_pkg_version: "1.0.36",
srcs: ["src/lib.rs"],
edition: "2018",
features: [
@@ -47,13 +49,10 @@ rust_library_host {
"proc-macro",
"span-locations",
],
- flags: [
- "--cfg hygiene",
- "--cfg lexerror_display",
- "--cfg proc_macro_span",
- "--cfg span_locations",
- "--cfg use_proc_macro",
- "--cfg wrap_proc_macro",
+ cfgs: [
+ "span_locations",
+ "use_proc_macro",
+ "wrap_proc_macro",
],
rustlibs: [
"libunicode_xid",
@@ -61,38 +60,11 @@ rust_library_host {
compile_multilib: "first",
}
-rust_test_host {
- name: "proc-macro2_host_test_src_lib",
- crate_name: "proc_macro2",
- srcs: ["src/lib.rs"],
- test_suites: ["general-tests"],
- auto_gen_config: true,
- test_options: {
- unit_test: true,
- },
- edition: "2018",
- features: [
- "default",
- "proc-macro",
- "span-locations",
- ],
- flags: [
- "--cfg hygiene",
- "--cfg lexerror_display",
- "--cfg proc_macro_span",
- "--cfg span_locations",
- "--cfg use_proc_macro",
- "--cfg wrap_proc_macro",
- ],
- rustlibs: [
- "libquote",
- "libunicode_xid",
- ],
-}
-
rust_defaults {
- name: "proc-macro2_defaults",
+ name: "proc-macro2_test_defaults",
crate_name: "proc_macro2",
+ cargo_env_compat: true,
+ cargo_pkg_version: "1.0.36",
test_suites: ["general-tests"],
auto_gen_config: true,
edition: "2018",
@@ -101,13 +73,10 @@ rust_defaults {
"proc-macro",
"span-locations",
],
- flags: [
- "--cfg hygiene",
- "--cfg lexerror_display",
- "--cfg proc_macro_span",
- "--cfg span_locations",
- "--cfg use_proc_macro",
- "--cfg wrap_proc_macro",
+ cfgs: [
+ "span_locations",
+ "use_proc_macro",
+ "wrap_proc_macro",
],
rustlibs: [
"libproc_macro2",
@@ -117,8 +86,8 @@ rust_defaults {
}
rust_test_host {
- name: "proc-macro2_host_test_tests_comments",
- defaults: ["proc-macro2_defaults"],
+ name: "proc-macro2_test_tests_comments",
+ defaults: ["proc-macro2_test_defaults"],
srcs: ["tests/comments.rs"],
test_options: {
unit_test: true,
@@ -126,8 +95,8 @@ rust_test_host {
}
rust_test_host {
- name: "proc-macro2_host_test_tests_features",
- defaults: ["proc-macro2_defaults"],
+ name: "proc-macro2_test_tests_features",
+ defaults: ["proc-macro2_test_defaults"],
srcs: ["tests/features.rs"],
test_options: {
unit_test: true,
@@ -135,8 +104,8 @@ rust_test_host {
}
rust_test_host {
- name: "proc-macro2_host_test_tests_marker",
- defaults: ["proc-macro2_defaults"],
+ name: "proc-macro2_test_tests_marker",
+ defaults: ["proc-macro2_test_defaults"],
srcs: ["tests/marker.rs"],
test_options: {
unit_test: true,
@@ -144,8 +113,8 @@ rust_test_host {
}
rust_test_host {
- name: "proc-macro2_host_test_tests_test",
- defaults: ["proc-macro2_defaults"],
+ name: "proc-macro2_test_tests_test",
+ defaults: ["proc-macro2_test_defaults"],
srcs: ["tests/test.rs"],
test_options: {
unit_test: true,
@@ -153,15 +122,10 @@ rust_test_host {
}
rust_test_host {
- name: "proc-macro2_host_test_tests_test_fmt",
- defaults: ["proc-macro2_defaults"],
+ name: "proc-macro2_test_tests_test_fmt",
+ defaults: ["proc-macro2_test_defaults"],
srcs: ["tests/test_fmt.rs"],
test_options: {
unit_test: true,
},
}
-
-// dependent_library ["feature_list"]
-// proc-macro2-1.0.26
-// quote-1.0.9
-// unicode-xid-0.2.1 "default"
diff --git a/Cargo.toml b/Cargo.toml
index 3bb4b8e..1272f37 100644
--- a/Cargo.toml
+++ b/Cargo.toml
@@ -3,25 +3,26 @@
# When uploading crates to the registry Cargo will automatically
# "normalize" Cargo.toml files for maximal compatibility
# with all versions of Cargo and also rewrite `path` dependencies
-# to registry (e.g., crates.io) dependencies
+# to registry (e.g., crates.io) dependencies.
#
-# If you believe there's an error in this file please file an
-# issue against the rust-lang/cargo repository. If you're
-# editing this file be aware that the upstream Cargo.toml
-# will likely look very different (and much more reasonable)
+# If you are reading this file be aware that the original Cargo.toml
+# will likely look very different (and much more reasonable).
+# See Cargo.toml.orig for the original contents.
[package]
edition = "2018"
+rust-version = "1.31"
name = "proc-macro2"
-version = "1.0.26"
-authors = ["Alex Crichton <alex@alexcrichton.com>", "David Tolnay <dtolnay@gmail.com>"]
+version = "1.0.36"
+authors = ["David Tolnay <dtolnay@gmail.com>", "Alex Crichton <alex@alexcrichton.com>"]
+autobenches = false
description = "A substitute implementation of the compiler's `proc_macro` API to decouple\ntoken-based libraries from the procedural macro use case.\n"
documentation = "https://docs.rs/proc-macro2"
readme = "README.md"
keywords = ["macros"]
categories = ["development-tools::procedural-macro-helpers"]
license = "MIT OR Apache-2.0"
-repository = "https://github.com/alexcrichton/proc-macro2"
+repository = "https://github.com/dtolnay/proc-macro2"
[package.metadata.docs.rs]
rustc-args = ["--cfg", "procmacro2_semver_exempt"]
rustdoc-args = ["--cfg", "procmacro2_semver_exempt", "--cfg", "doc_cfg"]
diff --git a/Cargo.toml.orig b/Cargo.toml.orig
index f229dbe..401bfaf 100644
--- a/Cargo.toml.orig
+++ b/Cargo.toml.orig
@@ -1,14 +1,16 @@
[package]
name = "proc-macro2"
-version = "1.0.26" # remember to update html_root_url
-authors = ["Alex Crichton <alex@alexcrichton.com>", "David Tolnay <dtolnay@gmail.com>"]
+version = "1.0.36" # remember to update html_root_url
+authors = ["David Tolnay <dtolnay@gmail.com>", "Alex Crichton <alex@alexcrichton.com>"]
license = "MIT OR Apache-2.0"
readme = "README.md"
keywords = ["macros"]
-repository = "https://github.com/alexcrichton/proc-macro2"
+repository = "https://github.com/dtolnay/proc-macro2"
documentation = "https://docs.rs/proc-macro2"
categories = ["development-tools::procedural-macro-helpers"]
edition = "2018"
+autobenches = false
+rust-version = "1.31"
description = """
A substitute implementation of the compiler's `proc_macro` API to decouple
token-based libraries from the procedural macro use case.
diff --git a/METADATA b/METADATA
index 1f73ea0..e2ded2b 100644
--- a/METADATA
+++ b/METADATA
@@ -7,13 +7,13 @@ third_party {
}
url {
type: ARCHIVE
- value: "https://static.crates.io/crates/proc-macro2/proc-macro2-1.0.26.crate"
+ value: "https://static.crates.io/crates/proc-macro2/proc-macro2-1.0.36.crate"
}
- version: "1.0.26"
+ version: "1.0.36"
license_type: NOTICE
last_upgrade_date {
- year: 2021
- month: 4
+ year: 2022
+ month: 3
day: 1
}
}
diff --git a/README.md b/README.md
index 3d05e87..35e1876 100644
--- a/README.md
+++ b/README.md
@@ -1,8 +1,9 @@
# proc-macro2
-[![Build Status](https://img.shields.io/github/workflow/status/alexcrichton/proc-macro2/build%20and%20test)](https://github.com/alexcrichton/proc-macro2/actions)
-[![Latest Version](https://img.shields.io/crates/v/proc-macro2.svg)](https://crates.io/crates/proc-macro2)
-[![Rust Documentation](https://img.shields.io/badge/api-rustdoc-blue.svg)](https://docs.rs/proc-macro2)
+[<img alt="github" src="https://img.shields.io/badge/github-dtolnay/proc--macro2-8da0cb?style=for-the-badge&labelColor=555555&logo=github" height="20">](https://github.com/dtolnay/proc-macro2)
+[<img alt="crates.io" src="https://img.shields.io/crates/v/proc-macro2.svg?style=for-the-badge&color=fc8d62&logo=rust" height="20">](https://crates.io/crates/proc-macro2)
+[<img alt="docs.rs" src="https://img.shields.io/badge/docs.rs-proc--macro2-66c2a5?style=for-the-badge&labelColor=555555&logoColor=white&logo=" height="20">](https://docs.rs/proc-macro2)
+[<img alt="build status" src="https://img.shields.io/github/workflow/status/dtolnay/proc-macro2/CI/master?style=for-the-badge" height="20">](https://github.com/dtolnay/proc-macro2/actions?query=branch%3Amaster)
A wrapper around the procedural macro API of the compiler's `proc_macro` crate.
This library serves two purposes:
diff --git a/TEST_MAPPING b/TEST_MAPPING
index 2e3c81b..76a8253 100644
--- a/TEST_MAPPING
+++ b/TEST_MAPPING
@@ -1,224 +1,231 @@
// Generated by update_crate_tests.py for tests that depend on this crate.
{
- "presubmit": [
+ "imports": [
{
- "name": "ZipFuseTest"
+ "path": "external/rust/crates/anyhow"
},
{
- "name": "anyhow_device_test_src_lib"
+ "path": "external/rust/crates/arbitrary"
},
{
- "name": "anyhow_device_test_tests_test_autotrait"
+ "path": "external/rust/crates/argh"
},
{
- "name": "anyhow_device_test_tests_test_boxed"
+ "path": "external/rust/crates/base64"
},
{
- "name": "anyhow_device_test_tests_test_chain"
+ "path": "external/rust/crates/bitflags"
},
{
- "name": "anyhow_device_test_tests_test_context"
+ "path": "external/rust/crates/bytes"
},
{
- "name": "anyhow_device_test_tests_test_convert"
+ "path": "external/rust/crates/either"
},
{
- "name": "anyhow_device_test_tests_test_downcast"
+ "path": "external/rust/crates/futures-util"
},
{
- "name": "anyhow_device_test_tests_test_ffi"
+ "path": "external/rust/crates/jni"
},
{
- "name": "anyhow_device_test_tests_test_fmt"
+ "path": "external/rust/crates/libm"
},
{
- "name": "anyhow_device_test_tests_test_macros"
+ "path": "external/rust/crates/libsqlite3-sys"
},
{
- "name": "anyhow_device_test_tests_test_repr"
+ "path": "external/rust/crates/oid-registry"
},
{
- "name": "anyhow_device_test_tests_test_source"
+ "path": "external/rust/crates/rand_chacha"
},
{
- "name": "authfs_device_test_src_lib"
+ "path": "external/rust/crates/serde"
},
{
- "name": "doh_unit_test"
+ "path": "external/rust/crates/serde-xml-rs"
},
{
- "name": "either_device_test_src_lib"
+ "path": "external/rust/crates/serde_cbor"
},
{
- "name": "futures-util_device_test_src_lib"
+ "path": "external/rust/crates/slab"
},
{
- "name": "keystore2_crypto_test_rust"
+ "path": "external/rust/crates/tinytemplate"
},
{
- "name": "keystore2_selinux_test"
+ "path": "external/rust/crates/tinyvec"
},
{
- "name": "keystore2_test"
+ "path": "external/rust/crates/tokio"
},
{
- "name": "libm_device_test_src_lib"
+ "path": "external/rust/crates/tokio-test"
},
{
- "name": "libsqlite3-sys_device_test_src_lib"
+ "path": "external/rust/crates/unicode-bidi"
},
{
- "name": "serde_cbor_device_test_src_lib"
+ "path": "external/rust/crates/unicode-xid"
},
{
- "name": "serde_cbor_device_test_tests_bennofs"
- },
+ "path": "external/rust/crates/url"
+ }
+ ],
+ "presubmit": [
{
- "name": "serde_cbor_device_test_tests_canonical"
+ "name": "ZipFuseTest"
},
{
- "name": "serde_cbor_device_test_tests_de"
+ "name": "apkdmverity.test"
},
{
- "name": "serde_cbor_device_test_tests_enum"
+ "name": "authfs_device_test_src_lib"
},
{
- "name": "serde_cbor_device_test_tests_ser"
+ "name": "diced_open_dice_cbor_test"
},
{
- "name": "serde_cbor_device_test_tests_std_types"
+ "name": "diced_sample_inputs_test"
},
{
- "name": "serde_cbor_device_test_tests_tags"
+ "name": "diced_test"
},
{
- "name": "serde_cbor_device_test_tests_value"
+ "name": "diced_utils_test"
},
{
- "name": "serde_test_device_test_src_lib"
+ "name": "diced_vendor_test"
},
{
- "name": "tokio-test_device_test_src_lib"
+ "name": "doh_unit_test"
},
{
- "name": "tokio-test_device_test_tests_block_on"
+ "name": "keystore2_crypto_test_rust"
},
{
- "name": "tokio-test_device_test_tests_io"
+ "name": "keystore2_km_compat_test"
},
{
- "name": "tokio-test_device_test_tests_macros"
+ "name": "keystore2_selinux_concurrency_test"
},
{
- "name": "tokio_device_test_tests_buffered"
+ "name": "keystore2_selinux_test"
},
{
- "name": "tokio_device_test_tests_io_async_read"
+ "name": "keystore2_test"
},
{
- "name": "tokio_device_test_tests_io_copy_bidirectional"
+ "name": "keystore2_test_utils_test"
},
{
- "name": "tokio_device_test_tests_io_lines"
+ "name": "keystore2_vintf_test"
},
{
- "name": "tokio_device_test_tests_io_mem_stream"
+ "name": "legacykeystore_test"
},
{
- "name": "tokio_device_test_tests_io_read"
+ "name": "libapkverify.integration_test"
},
{
- "name": "tokio_device_test_tests_io_read_buf"
+ "name": "libapkverify.test"
},
{
- "name": "tokio_device_test_tests_io_read_to_end"
+ "name": "libcert_request_validator_tests"
},
{
- "name": "tokio_device_test_tests_io_take"
+ "name": "libidsig.test"
},
{
- "name": "tokio_device_test_tests_io_write"
+ "name": "librustutils_test"
},
{
- "name": "tokio_device_test_tests_io_write_all"
+ "name": "microdroid_manager_test"
},
{
- "name": "tokio_device_test_tests_io_write_buf"
+ "name": "rustBinderTest"
},
{
- "name": "tokio_device_test_tests_io_write_int"
+ "name": "virtualizationservice_device_test"
+ }
+ ],
+ "presubmit-rust": [
+ {
+ "name": "ZipFuseTest"
},
{
- "name": "tokio_device_test_tests_macros_join"
+ "name": "apkdmverity.test"
},
{
- "name": "tokio_device_test_tests_no_rt"
+ "name": "authfs_device_test_src_lib"
},
{
- "name": "tokio_device_test_tests_rt_basic"
+ "name": "diced_open_dice_cbor_test"
},
{
- "name": "tokio_device_test_tests_rt_threaded"
+ "name": "diced_sample_inputs_test"
},
{
- "name": "tokio_device_test_tests_sync_barrier"
+ "name": "diced_test"
},
{
- "name": "tokio_device_test_tests_sync_broadcast"
+ "name": "diced_utils_test"
},
{
- "name": "tokio_device_test_tests_sync_errors"
+ "name": "diced_vendor_test"
},
{
- "name": "tokio_device_test_tests_sync_mpsc"
+ "name": "doh_unit_test"
},
{
- "name": "tokio_device_test_tests_sync_mutex_owned"
+ "name": "keystore2_crypto_test_rust"
},
{
- "name": "tokio_device_test_tests_sync_rwlock"
+ "name": "keystore2_km_compat_test"
},
{
- "name": "tokio_device_test_tests_sync_watch"
+ "name": "keystore2_selinux_concurrency_test"
},
{
- "name": "tokio_device_test_tests_task_local"
+ "name": "keystore2_selinux_test"
},
{
- "name": "tokio_device_test_tests_task_local_set"
+ "name": "keystore2_test"
},
{
- "name": "tokio_device_test_tests_tcp_accept"
+ "name": "keystore2_test_utils_test"
},
{
- "name": "tokio_device_test_tests_tcp_echo"
+ "name": "keystore2_vintf_test"
},
{
- "name": "tokio_device_test_tests_tcp_into_std"
+ "name": "legacykeystore_test"
},
{
- "name": "tokio_device_test_tests_tcp_shutdown"
+ "name": "libapkverify.integration_test"
},
{
- "name": "tokio_device_test_tests_time_rt"
+ "name": "libapkverify.test"
},
{
- "name": "tokio_device_test_tests_uds_split"
+ "name": "libcert_request_validator_tests"
},
{
- "name": "unicode-bidi_device_test_src_lib"
+ "name": "libidsig.test"
},
{
- "name": "url_device_test_src_lib"
+ "name": "librustutils_test"
},
{
- "name": "url_device_test_tests_data"
+ "name": "microdroid_manager_test"
},
{
- "name": "url_device_test_tests_unit"
+ "name": "rustBinderTest"
},
{
- "name": "vpnprofilestore_test"
+ "name": "virtualizationservice_device_test"
}
]
}
diff --git a/build.rs b/build.rs
index b247d87..946be6e 100644
--- a/build.rs
+++ b/build.rs
@@ -33,8 +33,15 @@
// location of a token. Enabled by procmacro2_semver_exempt or the
// "span-locations" Cargo cfg. This is behind a cfg because tracking
// location inside spans is a performance hit.
+//
+// "is_available"
+// Use proc_macro::is_available() to detect if the proc macro API is
+// available or needs to be polyfilled instead of trying to use the proc
+// macro API and catching a panic if it isn't available. Enabled on Rust
+// 1.57+.
use std::env;
+use std::iter;
use std::process::{self, Command};
use std::str;
@@ -51,9 +58,10 @@ fn main() {
process::exit(1);
}
- let semver_exempt = cfg!(procmacro2_semver_exempt);
+ let docs_rs = env::var_os("DOCS_RS").is_some();
+ let semver_exempt = cfg!(procmacro2_semver_exempt) || docs_rs;
if semver_exempt {
- // https://github.com/alexcrichton/proc-macro2/issues/147
+ // https://github.com/dtolnay/proc-macro2/issues/147
println!("cargo:rustc-cfg=procmacro2_semver_exempt");
}
@@ -69,12 +77,24 @@ fn main() {
println!("cargo:rustc-cfg=no_bind_by_move_pattern_guard");
}
- if version.minor >= 44 {
- println!("cargo:rustc-cfg=lexerror_display");
+ if version.minor < 44 {
+ println!("cargo:rustc-cfg=no_lexerror_display");
+ }
+
+ if version.minor < 45 {
+ println!("cargo:rustc-cfg=no_hygiene");
+ }
+
+ if version.minor < 54 {
+ println!("cargo:rustc-cfg=no_literal_from_str");
+ }
+
+ if version.minor < 55 {
+ println!("cargo:rustc-cfg=no_group_open_close");
}
- if version.minor >= 45 {
- println!("cargo:rustc-cfg=hygiene");
+ if version.minor < 57 {
+ println!("cargo:rustc-cfg=no_is_available");
}
let target = env::var("TARGET").unwrap();
@@ -132,15 +152,33 @@ fn feature_allowed(feature: &str) -> bool {
//
// -Zallow-features=feature1,feature2
- if let Some(rustflags) = env::var_os("RUSTFLAGS") {
- for mut flag in rustflags.to_string_lossy().split(' ') {
- if flag.starts_with("-Z") {
- flag = &flag["-Z".len()..];
- }
- if flag.starts_with("allow-features=") {
- flag = &flag["allow-features=".len()..];
- return flag.split(',').any(|allowed| allowed == feature);
- }
+ let flags_var;
+ let flags_var_string;
+ let mut flags_var_split;
+ let mut flags_none;
+ let flags: &mut dyn Iterator<Item = &str> =
+ if let Some(encoded_rustflags) = env::var_os("CARGO_ENCODED_RUSTFLAGS") {
+ flags_var = encoded_rustflags;
+ flags_var_string = flags_var.to_string_lossy();
+ flags_var_split = flags_var_string.split('\x1f');
+ &mut flags_var_split
+ } else if let Some(rustflags) = env::var_os("RUSTFLAGS") {
+ flags_var = rustflags;
+ flags_var_string = flags_var.to_string_lossy();
+ flags_var_split = flags_var_string.split(' ');
+ &mut flags_var_split
+ } else {
+ flags_none = iter::empty();
+ &mut flags_none
+ };
+
+ for mut flag in flags {
+ if flag.starts_with("-Z") {
+ flag = &flag["-Z".len()..];
+ }
+ if flag.starts_with("allow-features=") {
+ flag = &flag["allow-features=".len()..];
+ return flag.split(',').any(|allowed| allowed == feature);
}
}
diff --git a/cargo2android.json b/cargo2android.json
new file mode 100644
index 0000000..45a2954
--- /dev/null
+++ b/cargo2android.json
@@ -0,0 +1,6 @@
+{
+ "features": "default,span-locations",
+ "host-first-multilib": true,
+ "run": true,
+ "tests": true
+} \ No newline at end of file
diff --git a/src/detection.rs b/src/detection.rs
index c597bc9..d139b73 100644
--- a/src/detection.rs
+++ b/src/detection.rs
@@ -1,12 +1,11 @@
-use std::panic::{self, PanicInfo};
-use std::sync::atomic::*;
+use std::sync::atomic::{AtomicUsize, Ordering};
use std::sync::Once;
static WORKS: AtomicUsize = AtomicUsize::new(0);
static INIT: Once = Once::new();
pub(crate) fn inside_proc_macro() -> bool {
- match WORKS.load(Ordering::SeqCst) {
+ match WORKS.load(Ordering::Relaxed) {
1 => return false,
2 => return true,
_ => {}
@@ -17,13 +16,19 @@ pub(crate) fn inside_proc_macro() -> bool {
}
pub(crate) fn force_fallback() {
- WORKS.store(1, Ordering::SeqCst);
+ WORKS.store(1, Ordering::Relaxed);
}
pub(crate) fn unforce_fallback() {
initialize();
}
+#[cfg(not(no_is_available))]
+fn initialize() {
+ let available = proc_macro::is_available();
+ WORKS.store(available as usize + 1, Ordering::Relaxed);
+}
+
// Swap in a null panic hook to avoid printing "thread panicked" to stderr,
// then use catch_unwind to determine whether the compiler's proc_macro is
// working. When proc-macro2 is used from outside of a procedural macro all
@@ -48,7 +53,10 @@ pub(crate) fn unforce_fallback() {
// here. For now, if a user needs to guarantee that this failure mode does
// not occur, they need to call e.g. `proc_macro2::Span::call_site()` from
// the main thread before launching any other threads.
+#[cfg(no_is_available)]
fn initialize() {
+ use std::panic::{self, PanicInfo};
+
type PanicHook = dyn Fn(&PanicInfo) + Sync + Send + 'static;
let null_hook: Box<PanicHook> = Box::new(|_panic_info| { /* ignore */ });
@@ -57,7 +65,7 @@ fn initialize() {
panic::set_hook(null_hook);
let works = panic::catch_unwind(proc_macro::Span::call_site).is_ok();
- WORKS.store(works as usize + 1, Ordering::SeqCst);
+ WORKS.store(works as usize + 1, Ordering::Relaxed);
let hopefully_null_hook = panic::take_hook();
panic::set_hook(original_hook);
diff --git a/src/fallback.rs b/src/fallback.rs
index 50d10db..ac5437d 100644
--- a/src/fallback.rs
+++ b/src/fallback.rs
@@ -31,7 +31,7 @@ pub fn unforce() {
#[derive(Clone)]
pub(crate) struct TokenStream {
- pub(crate) inner: Vec<TokenTree>,
+ inner: Vec<TokenTree>,
}
#[derive(Debug)]
@@ -43,10 +43,16 @@ impl LexError {
pub(crate) fn span(&self) -> Span {
self.span
}
+
+ fn call_site() -> Self {
+ LexError {
+ span: Span::call_site(),
+ }
+ }
}
impl TokenStream {
- pub fn new() -> TokenStream {
+ pub fn new() -> Self {
TokenStream { inner: Vec::new() }
}
@@ -59,7 +65,7 @@ impl TokenStream {
}
fn push_token(&mut self, token: TokenTree) {
- // https://github.com/alexcrichton/proc-macro2/issues/235
+ // https://github.com/dtolnay/proc-macro2/issues/235
match token {
#[cfg(not(no_bind_by_move_pattern_guard))]
TokenTree::Literal(crate::Literal {
@@ -68,7 +74,7 @@ impl TokenStream {
#[cfg(not(wrap_proc_macro))]
inner: literal,
..
- }) if literal.text.starts_with('-') => {
+ }) if literal.repr.starts_with('-') => {
push_negative_literal(self, literal);
}
#[cfg(no_bind_by_move_pattern_guard)]
@@ -79,7 +85,7 @@ impl TokenStream {
inner: literal,
..
}) => {
- if literal.text.starts_with('-') {
+ if literal.repr.starts_with('-') {
push_negative_literal(self, literal);
} else {
self.inner
@@ -91,7 +97,7 @@ impl TokenStream {
#[cold]
fn push_negative_literal(stream: &mut TokenStream, mut literal: Literal) {
- literal.text.remove(0);
+ literal.repr.remove(0);
let mut punct = crate::Punct::new('-', Spacing::Alone);
punct.set_span(crate::Span::_new_stable(literal.span));
stream.inner.push(TokenTree::Punct(punct));
@@ -102,6 +108,12 @@ impl TokenStream {
}
}
+impl From<Vec<TokenTree>> for TokenStream {
+ fn from(inner: Vec<TokenTree>) -> Self {
+ TokenStream { inner }
+ }
+}
+
// Nonrecursive to prevent stack overflow.
impl Drop for TokenStream {
fn drop(&mut self) {
@@ -113,7 +125,7 @@ impl Drop for TokenStream {
#[cfg(wrap_proc_macro)]
let group = match group {
crate::imp::Group::Fallback(group) => group,
- _ => continue,
+ crate::imp::Group::Compiler(_) => continue,
};
let mut group = group;
self.inner.extend(group.stream.take_inner());
@@ -173,7 +185,7 @@ impl Display for TokenStream {
Display::fmt(tt, f)
}
TokenTree::Literal(tt) => Display::fmt(tt, f),
- }?
+ }?;
}
Ok(())
@@ -411,22 +423,22 @@ pub(crate) struct Span {
impl Span {
#[cfg(not(span_locations))]
- pub fn call_site() -> Span {
+ pub fn call_site() -> Self {
Span {}
}
#[cfg(span_locations)]
- pub fn call_site() -> Span {
+ pub fn call_site() -> Self {
Span { lo: 0, hi: 0 }
}
- #[cfg(hygiene)]
- pub fn mixed_site() -> Span {
+ #[cfg(not(no_hygiene))]
+ pub fn mixed_site() -> Self {
Span::call_site()
}
#[cfg(procmacro2_semver_exempt)]
- pub fn def_site() -> Span {
+ pub fn def_site() -> Self {
Span::call_site()
}
@@ -548,7 +560,7 @@ pub(crate) struct Group {
}
impl Group {
- pub fn new(delimiter: Delimiter, stream: TokenStream) -> Group {
+ pub fn new(delimiter: Delimiter, stream: TokenStream) -> Self {
Group {
delimiter,
stream,
@@ -626,7 +638,7 @@ pub(crate) struct Ident {
}
impl Ident {
- fn _new(string: &str, raw: bool, span: Span) -> Ident {
+ fn _new(string: &str, raw: bool, span: Span) -> Self {
validate_ident(string);
Ident {
@@ -636,11 +648,11 @@ impl Ident {
}
}
- pub fn new(string: &str, span: Span) -> Ident {
+ pub fn new(string: &str, span: Span) -> Self {
Ident::_new(string, false, span)
}
- pub fn new_raw(string: &str, span: Span) -> Ident {
+ pub fn new_raw(string: &str, span: Span) -> Self {
Ident::_new(string, true, span)
}
@@ -750,7 +762,7 @@ impl Debug for Ident {
#[derive(Clone)]
pub(crate) struct Literal {
- text: String,
+ repr: String,
span: Span,
}
@@ -771,13 +783,17 @@ macro_rules! unsuffixed_numbers {
}
impl Literal {
- pub(crate) fn _new(text: String) -> Literal {
+ pub(crate) fn _new(repr: String) -> Self {
Literal {
- text,
+ repr,
span: Span::call_site(),
}
}
+ pub(crate) unsafe fn from_str_unchecked(repr: &str) -> Self {
+ Literal::_new(repr.to_owned())
+ }
+
suffixed_numbers! {
u8_suffixed => u8,
u16_suffixed => u16,
@@ -828,31 +844,31 @@ impl Literal {
}
pub fn string(t: &str) -> Literal {
- let mut text = String::with_capacity(t.len() + 2);
- text.push('"');
+ let mut repr = String::with_capacity(t.len() + 2);
+ repr.push('"');
for c in t.chars() {
if c == '\'' {
// escape_debug turns this into "\'" which is unnecessary.
- text.push(c);
+ repr.push(c);
} else {
- text.extend(c.escape_debug());
+ repr.extend(c.escape_debug());
}
}
- text.push('"');
- Literal::_new(text)
+ repr.push('"');
+ Literal::_new(repr)
}
pub fn character(t: char) -> Literal {
- let mut text = String::new();
- text.push('\'');
+ let mut repr = String::new();
+ repr.push('\'');
if t == '"' {
// escape_debug turns this into '\"' which is unnecessary.
- text.push(t);
+ repr.push(t);
} else {
- text.extend(t.escape_debug());
+ repr.extend(t.escape_debug());
}
- text.push('\'');
- Literal::_new(text)
+ repr.push('\'');
+ Literal::_new(repr)
}
pub fn byte_string(bytes: &[u8]) -> Literal {
@@ -887,16 +903,40 @@ impl Literal {
}
}
+impl FromStr for Literal {
+ type Err = LexError;
+
+ fn from_str(mut repr: &str) -> Result<Self, Self::Err> {
+ let negative = repr.starts_with('-');
+ if negative {
+ repr = &repr[1..];
+ if !repr.starts_with(|ch: char| ch.is_ascii_digit()) {
+ return Err(LexError::call_site());
+ }
+ }
+ let cursor = get_cursor(repr);
+ if let Ok((_rest, mut literal)) = parse::literal(cursor) {
+ if literal.repr.len() == repr.len() {
+ if negative {
+ literal.repr.insert(0, '-');
+ }
+ return Ok(literal);
+ }
+ }
+ Err(LexError::call_site())
+ }
+}
+
impl Display for Literal {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
- Display::fmt(&self.text, f)
+ Display::fmt(&self.repr, f)
}
}
impl Debug for Literal {
fn fmt(&self, fmt: &mut fmt::Formatter) -> fmt::Result {
let mut debug = fmt.debug_struct("Literal");
- debug.field("lit", &format_args!("{}", self.text));
+ debug.field("lit", &format_args!("{}", self.repr));
debug_span_field_if_nontrivial(&mut debug, self.span);
debug.finish()
}
diff --git a/src/lib.rs b/src/lib.rs
index 9dec309..6edaf42 100644
--- a/src/lib.rs
+++ b/src/lib.rs
@@ -1,3 +1,11 @@
+//! [![github]](https://github.com/dtolnay/proc-macro2)&ensp;[![crates-io]](https://crates.io/crates/proc-macro2)&ensp;[![docs-rs]](crate)
+//!
+//! [github]: https://img.shields.io/badge/github-8da0cb?style=for-the-badge&labelColor=555555&logo=github
+//! [crates-io]: https://img.shields.io/badge/crates.io-fc8d62?style=for-the-badge&labelColor=555555&logo=rust
+//! [docs-rs]: https://img.shields.io/badge/docs.rs-66c2a5?style=for-the-badge&labelColor=555555&logoColor=white&logo=
+//!
+//! <br>
+//!
//! A wrapper around the procedural macro API of the compiler's [`proc_macro`]
//! crate. This library serves two purposes:
//!
@@ -78,11 +86,34 @@
//! a different thread.
// Proc-macro2 types in rustdoc of other crates get linked to here.
-#![doc(html_root_url = "https://docs.rs/proc-macro2/1.0.26")]
+#![doc(html_root_url = "https://docs.rs/proc-macro2/1.0.36")]
#![cfg_attr(any(proc_macro_span, super_unstable), feature(proc_macro_span))]
-#![cfg_attr(super_unstable, feature(proc_macro_raw_ident, proc_macro_def_site))]
+#![cfg_attr(super_unstable, feature(proc_macro_def_site))]
#![cfg_attr(doc_cfg, feature(doc_cfg))]
-#![allow(clippy::needless_doctest_main, clippy::vec_init_then_push)]
+#![allow(
+ clippy::cast_lossless,
+ clippy::cast_possible_truncation,
+ clippy::doc_markdown,
+ clippy::items_after_statements,
+ clippy::manual_assert,
+ clippy::must_use_candidate,
+ clippy::needless_doctest_main,
+ clippy::return_self_not_must_use,
+ clippy::shadow_unrelated,
+ clippy::trivially_copy_pass_by_ref,
+ clippy::unnecessary_wraps,
+ clippy::unused_self,
+ clippy::used_underscore_binding,
+ clippy::vec_init_then_push
+)]
+
+#[cfg(all(procmacro2_semver_exempt, wrap_proc_macro, not(super_unstable)))]
+compile_error! {"\
+ Something is not right. If you've tried to turn on \
+ procmacro2_semver_exempt, you need to ensure that it \
+ is turned on for the compilation of the proc-macro2 \
+ build script as well.
+"}
#[cfg(use_proc_macro)]
extern crate proc_macro;
@@ -135,14 +166,14 @@ pub struct LexError {
}
impl TokenStream {
- fn _new(inner: imp::TokenStream) -> TokenStream {
+ fn _new(inner: imp::TokenStream) -> Self {
TokenStream {
inner,
_marker: Marker,
}
}
- fn _new_stable(inner: fallback::TokenStream) -> TokenStream {
+ fn _new_stable(inner: fallback::TokenStream) -> Self {
TokenStream {
inner: inner.into(),
_marker: Marker,
@@ -150,7 +181,7 @@ impl TokenStream {
}
/// Returns an empty `TokenStream` containing no token trees.
- pub fn new() -> TokenStream {
+ pub fn new() -> Self {
TokenStream::_new(imp::TokenStream::new())
}
@@ -210,14 +241,14 @@ impl From<TokenTree> for TokenStream {
impl Extend<TokenTree> for TokenStream {
fn extend<I: IntoIterator<Item = TokenTree>>(&mut self, streams: I) {
- self.inner.extend(streams)
+ self.inner.extend(streams);
}
}
impl Extend<TokenStream> for TokenStream {
fn extend<I: IntoIterator<Item = TokenStream>>(&mut self, streams: I) {
self.inner
- .extend(streams.into_iter().map(|stream| stream.inner))
+ .extend(streams.into_iter().map(|stream| stream.inner));
}
}
@@ -273,7 +304,7 @@ impl Error for LexError {}
/// The source file of a given `Span`.
///
/// This type is semver exempt and not exposed by default.
-#[cfg(procmacro2_semver_exempt)]
+#[cfg(all(procmacro2_semver_exempt, any(not(wrap_proc_macro), super_unstable)))]
#[cfg_attr(doc_cfg, doc(cfg(procmacro2_semver_exempt)))]
#[derive(Clone, PartialEq, Eq)]
pub struct SourceFile {
@@ -281,7 +312,7 @@ pub struct SourceFile {
_marker: Marker,
}
-#[cfg(procmacro2_semver_exempt)]
+#[cfg(all(procmacro2_semver_exempt, any(not(wrap_proc_macro), super_unstable)))]
impl SourceFile {
fn _new(inner: imp::SourceFile) -> Self {
SourceFile {
@@ -314,7 +345,7 @@ impl SourceFile {
}
}
-#[cfg(procmacro2_semver_exempt)]
+#[cfg(all(procmacro2_semver_exempt, any(not(wrap_proc_macro), super_unstable)))]
impl Debug for SourceFile {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
Debug::fmt(&self.inner, f)
@@ -360,14 +391,14 @@ pub struct Span {
}
impl Span {
- fn _new(inner: imp::Span) -> Span {
+ fn _new(inner: imp::Span) -> Self {
Span {
inner,
_marker: Marker,
}
}
- fn _new_stable(inner: fallback::Span) -> Span {
+ fn _new_stable(inner: fallback::Span) -> Self {
Span {
inner: inner.into(),
_marker: Marker,
@@ -379,7 +410,7 @@ impl Span {
/// Identifiers created with this span will be resolved as if they were
/// written directly at the macro call location (call-site hygiene) and
/// other code at the macro call site will be able to refer to them as well.
- pub fn call_site() -> Span {
+ pub fn call_site() -> Self {
Span::_new(imp::Span::call_site())
}
@@ -388,8 +419,8 @@ impl Span {
/// of the macro. This is the same hygiene behavior as `macro_rules`.
///
/// This function requires Rust 1.45 or later.
- #[cfg(hygiene)]
- pub fn mixed_site() -> Span {
+ #[cfg(not(no_hygiene))]
+ pub fn mixed_site() -> Self {
Span::_new(imp::Span::mixed_site())
}
@@ -398,7 +429,7 @@ impl Span {
/// This method is semver exempt and not exposed by default.
#[cfg(procmacro2_semver_exempt)]
#[cfg_attr(doc_cfg, doc(cfg(procmacro2_semver_exempt)))]
- pub fn def_site() -> Span {
+ pub fn def_site() -> Self {
Span::_new(imp::Span::def_site())
}
@@ -439,7 +470,7 @@ impl Span {
/// The original source file into which this span points.
///
/// This method is semver exempt and not exposed by default.
- #[cfg(procmacro2_semver_exempt)]
+ #[cfg(all(procmacro2_semver_exempt, any(not(wrap_proc_macro), super_unstable)))]
#[cfg_attr(doc_cfg, doc(cfg(procmacro2_semver_exempt)))]
pub fn source_file(&self) -> SourceFile {
SourceFile::_new(self.inner.source_file())
@@ -649,7 +680,7 @@ impl Group {
/// This constructor will set the span for this group to
/// `Span::call_site()`. To change the span you can use the `set_span`
/// method below.
- pub fn new(delimiter: Delimiter, stream: TokenStream) -> Group {
+ pub fn new(delimiter: Delimiter, stream: TokenStream) -> Self {
Group {
inner: imp::Group::new(delimiter, stream.inner),
}
@@ -706,7 +737,7 @@ impl Group {
/// by this group, but rather it will only set the span of the delimiter
/// tokens at the level of the `Group`.
pub fn set_span(&mut self, span: Span) {
- self.inner.set_span(span.inner)
+ self.inner.set_span(span.inner);
}
}
@@ -757,7 +788,7 @@ impl Punct {
///
/// The returned `Punct` will have the default span of `Span::call_site()`
/// which can be further configured with the `set_span` method below.
- pub fn new(ch: char, spacing: Spacing) -> Punct {
+ pub fn new(ch: char, spacing: Spacing) -> Self {
Punct {
ch,
spacing,
@@ -879,7 +910,7 @@ pub struct Ident {
}
impl Ident {
- fn _new(inner: imp::Ident) -> Ident {
+ fn _new(inner: imp::Ident) -> Self {
Ident {
inner,
_marker: Marker,
@@ -917,7 +948,7 @@ impl Ident {
/// style="padding-right:0;">syn::parse_str</code></a><code
/// style="padding-left:0;">::&lt;Ident&gt;</code>
/// rather than `Ident::new`.
- pub fn new(string: &str, span: Span) -> Ident {
+ pub fn new(string: &str, span: Span) -> Self {
Ident::_new(imp::Ident::new(string, span.inner))
}
@@ -926,11 +957,11 @@ impl Ident {
/// This method is semver exempt and not exposed by default.
#[cfg(procmacro2_semver_exempt)]
#[cfg_attr(doc_cfg, doc(cfg(procmacro2_semver_exempt)))]
- pub fn new_raw(string: &str, span: Span) -> Ident {
+ pub fn new_raw(string: &str, span: Span) -> Self {
Ident::_new_raw(string, span)
}
- fn _new_raw(string: &str, span: Span) -> Ident {
+ fn _new_raw(string: &str, span: Span) -> Self {
Ident::_new(imp::Ident::new_raw(string, span.inner))
}
@@ -977,7 +1008,7 @@ impl Ord for Ident {
impl Hash for Ident {
fn hash<H: Hasher>(&self, hasher: &mut H) {
- self.to_string().hash(hasher)
+ self.to_string().hash(hasher);
}
}
@@ -1048,14 +1079,14 @@ macro_rules! unsuffixed_int_literals {
}
impl Literal {
- fn _new(inner: imp::Literal) -> Literal {
+ fn _new(inner: imp::Literal) -> Self {
Literal {
inner,
_marker: Marker,
}
}
- fn _new_stable(inner: fallback::Literal) -> Literal {
+ fn _new_stable(inner: fallback::Literal) -> Self {
Literal {
inner: inner.into(),
_marker: Marker,
@@ -1201,6 +1232,26 @@ impl Literal {
pub fn subspan<R: RangeBounds<usize>>(&self, range: R) -> Option<Span> {
self.inner.subspan(range).map(Span::_new)
}
+
+ // Intended for the `quote!` macro to use when constructing a proc-macro2
+ // token out of a macro_rules $:literal token, which is already known to be
+ // a valid literal. This avoids reparsing/validating the literal's string
+ // representation. This is not public API other than for quote.
+ #[doc(hidden)]
+ pub unsafe fn from_str_unchecked(repr: &str) -> Self {
+ Literal::_new(imp::Literal::from_str_unchecked(repr))
+ }
+}
+
+impl FromStr for Literal {
+ type Err = LexError;
+
+ fn from_str(repr: &str) -> Result<Self, LexError> {
+ repr.parse().map(Literal::_new).map_err(|inner| LexError {
+ inner,
+ _marker: Marker,
+ })
+ }
}
impl Debug for Literal {
diff --git a/src/parse.rs b/src/parse.rs
index e5caed8..f77213a 100644
--- a/src/parse.rs
+++ b/src/parse.rs
@@ -59,7 +59,7 @@ impl<'a> Cursor<'a> {
}
}
-struct Reject;
+pub(crate) struct Reject;
type PResult<'a, O> = Result<(Cursor<'a>, O), Reject>;
fn skip_whitespace(input: Cursor) -> Cursor {
@@ -168,7 +168,7 @@ pub(crate) fn token_stream(mut input: Cursor) -> Result<TokenStream, LexError> {
let first = match input.bytes().next() {
Some(first) => first,
None => match stack.last() {
- None => return Ok(TokenStream { inner: trees }),
+ None => return Ok(TokenStream::from(trees)),
#[cfg(span_locations)]
Some((lo, _frame)) => {
return Err(LexError {
@@ -209,7 +209,7 @@ pub(crate) fn token_stream(mut input: Cursor) -> Result<TokenStream, LexError> {
return Err(lex_error(input));
}
input = input.advance(1);
- let mut g = Group::new(open_delimiter, TokenStream { inner: trees });
+ let mut g = Group::new(open_delimiter, TokenStream::from(trees));
g.set_span(Span {
#[cfg(span_locations)]
lo,
@@ -310,7 +310,7 @@ fn ident_not_raw(input: Cursor) -> PResult<&str> {
Ok((input.advance(end), &input.rest[..end]))
}
-fn literal(input: Cursor) -> PResult<Literal> {
+pub(crate) fn literal(input: Cursor) -> PResult<Literal> {
let rest = literal_nocapture(input)?;
let end = input.len() - rest.len();
Ok((rest, Literal::_new(input.rest[..end].to_string())))
@@ -461,7 +461,7 @@ fn cooked_byte_string(mut input: Cursor) -> Result<Cursor, Reject> {
fn raw_string(input: Cursor) -> Result<Cursor, Reject> {
let mut chars = input.char_indices();
let mut n = 0;
- while let Some((i, ch)) = chars.next() {
+ for (i, ch) in &mut chars {
match ch {
'"' => {
n = i;
@@ -621,8 +621,7 @@ fn float_digits(input: Cursor) -> Result<Cursor, Reject> {
chars.next();
if chars
.peek()
- .map(|&ch| ch == '.' || is_ident_start(ch))
- .unwrap_or(false)
+ .map_or(false, |&ch| ch == '.' || is_ident_start(ch))
{
return Err(Reject);
}
@@ -817,12 +816,12 @@ fn doc_comment(input: Cursor) -> PResult<Vec<TokenTree>> {
TokenTree::Punct(Punct::new('=', Spacing::Alone)),
TokenTree::Literal(crate::Literal::string(comment)),
];
- for tt in stream.iter_mut() {
+ for tt in &mut stream {
tt.set_span(span);
}
- let group = Group::new(Delimiter::Bracket, stream.into_iter().collect());
+ let group = Group::new(Delimiter::Bracket, TokenStream::from(stream));
trees.push(crate::Group::_new_stable(group).into());
- for tt in trees.iter_mut() {
+ for tt in &mut trees {
tt.set_span(span);
}
Ok((rest, trees))
diff --git a/src/wrapper.rs b/src/wrapper.rs
index 24d86e8..2ba76cc 100644
--- a/src/wrapper.rs
+++ b/src/wrapper.rs
@@ -29,6 +29,14 @@ pub(crate) enum LexError {
Fallback(fallback::LexError),
}
+impl LexError {
+ fn call_site() -> Self {
+ LexError::Fallback(fallback::LexError {
+ span: fallback::Span::call_site(),
+ })
+ }
+}
+
fn mismatch() -> ! {
panic!("stable/nightly mismatch")
}
@@ -61,7 +69,7 @@ impl DeferredTokenStream {
}
impl TokenStream {
- pub fn new() -> TokenStream {
+ pub fn new() -> Self {
if inside_proc_macro() {
TokenStream::Compiler(DeferredTokenStream::new(proc_macro::TokenStream::new()))
} else {
@@ -108,11 +116,7 @@ impl FromStr for TokenStream {
// Work around https://github.com/rust-lang/rust/issues/58736.
fn proc_macro_parse(src: &str) -> Result<proc_macro::TokenStream, LexError> {
let result = panic::catch_unwind(|| src.parse().map_err(LexError::Compiler));
- result.unwrap_or_else(|_| {
- Err(LexError::Fallback(fallback::LexError {
- span: fallback::Span::call_site(),
- }))
- })
+ result.unwrap_or_else(|_| Err(LexError::call_site()))
}
impl Display for TokenStream {
@@ -280,9 +284,9 @@ impl Debug for LexError {
impl Display for LexError {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
match self {
- #[cfg(lexerror_display)]
+ #[cfg(not(no_lexerror_display))]
LexError::Compiler(e) => Display::fmt(e, f),
- #[cfg(not(lexerror_display))]
+ #[cfg(no_lexerror_display)]
LexError::Compiler(_e) => Display::fmt(
&fallback::LexError {
span: fallback::Span::call_site(),
@@ -404,7 +408,7 @@ pub(crate) enum Span {
}
impl Span {
- pub fn call_site() -> Span {
+ pub fn call_site() -> Self {
if inside_proc_macro() {
Span::Compiler(proc_macro::Span::call_site())
} else {
@@ -412,8 +416,8 @@ impl Span {
}
}
- #[cfg(hygiene)]
- pub fn mixed_site() -> Span {
+ #[cfg(not(no_hygiene))]
+ pub fn mixed_site() -> Self {
if inside_proc_macro() {
Span::Compiler(proc_macro::Span::mixed_site())
} else {
@@ -422,7 +426,7 @@ impl Span {
}
#[cfg(super_unstable)]
- pub fn def_site() -> Span {
+ pub fn def_site() -> Self {
if inside_proc_macro() {
Span::Compiler(proc_macro::Span::def_site())
} else {
@@ -432,11 +436,11 @@ impl Span {
pub fn resolved_at(&self, other: Span) -> Span {
match (self, other) {
- #[cfg(hygiene)]
+ #[cfg(not(no_hygiene))]
(Span::Compiler(a), Span::Compiler(b)) => Span::Compiler(a.resolved_at(b)),
// Name resolution affects semantics, but location is only cosmetic
- #[cfg(not(hygiene))]
+ #[cfg(no_hygiene)]
(Span::Compiler(_), Span::Compiler(_)) => other,
(Span::Fallback(a), Span::Fallback(b)) => Span::Fallback(a.resolved_at(b)),
@@ -446,11 +450,11 @@ impl Span {
pub fn located_at(&self, other: Span) -> Span {
match (self, other) {
- #[cfg(hygiene)]
+ #[cfg(not(no_hygiene))]
(Span::Compiler(a), Span::Compiler(b)) => Span::Compiler(a.located_at(b)),
// Name resolution affects semantics, but location is only cosmetic
- #[cfg(not(hygiene))]
+ #[cfg(no_hygiene)]
(Span::Compiler(_), Span::Compiler(_)) => *self,
(Span::Fallback(a), Span::Fallback(b)) => Span::Fallback(a.located_at(b)),
@@ -571,7 +575,7 @@ pub(crate) enum Group {
}
impl Group {
- pub fn new(delimiter: Delimiter, stream: TokenStream) -> Group {
+ pub fn new(delimiter: Delimiter, stream: TokenStream) -> Self {
match stream {
TokenStream::Compiler(tts) => {
let delimiter = match delimiter {
@@ -616,9 +620,9 @@ impl Group {
pub fn span_open(&self) -> Span {
match self {
- #[cfg(proc_macro_span)]
+ #[cfg(not(no_group_open_close))]
Group::Compiler(g) => Span::Compiler(g.span_open()),
- #[cfg(not(proc_macro_span))]
+ #[cfg(no_group_open_close)]
Group::Compiler(g) => Span::Compiler(g.span()),
Group::Fallback(g) => Span::Fallback(g.span_open()),
}
@@ -626,9 +630,9 @@ impl Group {
pub fn span_close(&self) -> Span {
match self {
- #[cfg(proc_macro_span)]
+ #[cfg(not(no_group_open_close))]
Group::Compiler(g) => Span::Compiler(g.span_close()),
- #[cfg(not(proc_macro_span))]
+ #[cfg(no_group_open_close)]
Group::Compiler(g) => Span::Compiler(g.span()),
Group::Fallback(g) => Span::Fallback(g.span_close()),
}
@@ -681,14 +685,14 @@ pub(crate) enum Ident {
}
impl Ident {
- pub fn new(string: &str, span: Span) -> Ident {
+ pub fn new(string: &str, span: Span) -> Self {
match span {
Span::Compiler(s) => Ident::Compiler(proc_macro::Ident::new(string, s)),
Span::Fallback(s) => Ident::Fallback(fallback::Ident::new(string, s)),
}
}
- pub fn new_raw(string: &str, span: Span) -> Ident {
+ pub fn new_raw(string: &str, span: Span) -> Self {
match span {
Span::Compiler(s) => {
let p: proc_macro::TokenStream = string.parse().unwrap();
@@ -800,6 +804,14 @@ macro_rules! unsuffixed_integers {
}
impl Literal {
+ pub unsafe fn from_str_unchecked(repr: &str) -> Self {
+ if inside_proc_macro() {
+ Literal::Compiler(compiler_literal_from_str(repr).expect("invalid literal"))
+ } else {
+ Literal::Fallback(fallback::Literal::from_str_unchecked(repr))
+ }
+ }
+
suffixed_numbers! {
u8_suffixed => u8,
u16_suffixed => u16,
@@ -912,6 +924,37 @@ impl From<fallback::Literal> for Literal {
}
}
+impl FromStr for Literal {
+ type Err = LexError;
+
+ fn from_str(repr: &str) -> Result<Self, Self::Err> {
+ if inside_proc_macro() {
+ compiler_literal_from_str(repr).map(Literal::Compiler)
+ } else {
+ let literal = fallback::Literal::from_str(repr)?;
+ Ok(Literal::Fallback(literal))
+ }
+ }
+}
+
+fn compiler_literal_from_str(repr: &str) -> Result<proc_macro::Literal, LexError> {
+ #[cfg(not(no_literal_from_str))]
+ {
+ proc_macro::Literal::from_str(repr).map_err(LexError::Compiler)
+ }
+ #[cfg(no_literal_from_str)]
+ {
+ let tokens = proc_macro_parse(repr)?;
+ let mut iter = tokens.into_iter();
+ if let (Some(proc_macro::TokenTree::Literal(literal)), None) = (iter.next(), iter.next()) {
+ if literal.to_string().len() == repr.len() {
+ return Ok(literal);
+ }
+ }
+ Err(LexError::call_site())
+ }
+}
+
impl Display for Literal {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
match self {
diff --git a/tests/comments.rs b/tests/comments.rs
index 708cccb..7174108 100644
--- a/tests/comments.rs
+++ b/tests/comments.rs
@@ -1,16 +1,16 @@
use proc_macro2::{Delimiter, Literal, Spacing, TokenStream, TokenTree};
// #[doc = "..."] -> "..."
-fn lit_of_outer_doc_comment(tokens: TokenStream) -> Literal {
+fn lit_of_outer_doc_comment(tokens: &TokenStream) -> Literal {
lit_of_doc_comment(tokens, false)
}
// #![doc = "..."] -> "..."
-fn lit_of_inner_doc_comment(tokens: TokenStream) -> Literal {
+fn lit_of_inner_doc_comment(tokens: &TokenStream) -> Literal {
lit_of_doc_comment(tokens, true)
}
-fn lit_of_doc_comment(tokens: TokenStream, inner: bool) -> Literal {
+fn lit_of_doc_comment(tokens: &TokenStream, inner: bool) -> Literal {
let mut iter = tokens.clone().into_iter();
match iter.next().unwrap() {
TokenTree::Punct(punct) => {
@@ -71,30 +71,30 @@ fn incomplete() {
#[test]
fn lit() {
let stream = "/// doc".parse::<TokenStream>().unwrap();
- let lit = lit_of_outer_doc_comment(stream);
+ let lit = lit_of_outer_doc_comment(&stream);
assert_eq!(lit.to_string(), "\" doc\"");
let stream = "//! doc".parse::<TokenStream>().unwrap();
- let lit = lit_of_inner_doc_comment(stream);
+ let lit = lit_of_inner_doc_comment(&stream);
assert_eq!(lit.to_string(), "\" doc\"");
let stream = "/** doc */".parse::<TokenStream>().unwrap();
- let lit = lit_of_outer_doc_comment(stream);
+ let lit = lit_of_outer_doc_comment(&stream);
assert_eq!(lit.to_string(), "\" doc \"");
let stream = "/*! doc */".parse::<TokenStream>().unwrap();
- let lit = lit_of_inner_doc_comment(stream);
+ let lit = lit_of_inner_doc_comment(&stream);
assert_eq!(lit.to_string(), "\" doc \"");
}
#[test]
fn carriage_return() {
let stream = "///\r\n".parse::<TokenStream>().unwrap();
- let lit = lit_of_outer_doc_comment(stream);
+ let lit = lit_of_outer_doc_comment(&stream);
assert_eq!(lit.to_string(), "\"\"");
let stream = "/**\r\n*/".parse::<TokenStream>().unwrap();
- let lit = lit_of_outer_doc_comment(stream);
+ let lit = lit_of_outer_doc_comment(&stream);
assert_eq!(lit.to_string(), "\"\\r\\n\"");
"///\r".parse::<TokenStream>().unwrap_err();
diff --git a/tests/marker.rs b/tests/marker.rs
index 70e5767..4fb2beb 100644
--- a/tests/marker.rs
+++ b/tests/marker.rs
@@ -1,4 +1,6 @@
-use proc_macro2::*;
+use proc_macro2::{
+ Delimiter, Group, Ident, LexError, Literal, Punct, Spacing, Span, TokenStream, TokenTree,
+};
macro_rules! assert_impl {
($ty:ident is $($marker:ident) and +) => {
@@ -51,7 +53,7 @@ assert_impl!(TokenTree is not Send or Sync);
#[cfg(procmacro2_semver_exempt)]
mod semver_exempt {
- use super::*;
+ use proc_macro2::{LineColumn, SourceFile};
assert_impl!(LineColumn is Send and Sync);
@@ -60,7 +62,11 @@ mod semver_exempt {
#[cfg(not(no_libprocmacro_unwind_safe))]
mod unwind_safe {
- use super::*;
+ use proc_macro2::{
+ Delimiter, Group, Ident, LexError, Literal, Punct, Spacing, Span, TokenStream, TokenTree,
+ };
+ #[cfg(procmacro2_semver_exempt)]
+ use proc_macro2::{LineColumn, SourceFile};
use std::panic::{RefUnwindSafe, UnwindSafe};
macro_rules! assert_unwind_safe {
diff --git a/tests/test.rs b/tests/test.rs
index 6d0a93e..ab82390 100644
--- a/tests/test.rs
+++ b/tests/test.rs
@@ -1,3 +1,5 @@
+#![allow(clippy::non_ascii_literal)]
+
use proc_macro2::{Ident, Literal, Punct, Spacing, Span, TokenStream, TokenTree};
use std::panic;
use std::str::{self, FromStr};
@@ -164,12 +166,33 @@ fn literal_iter_negative() {
}
#[test]
+fn literal_parse() {
+ assert!("1".parse::<Literal>().is_ok());
+ assert!("-1".parse::<Literal>().is_ok());
+ assert!("-1u12".parse::<Literal>().is_ok());
+ assert!("1.0".parse::<Literal>().is_ok());
+ assert!("-1.0".parse::<Literal>().is_ok());
+ assert!("-1.0f12".parse::<Literal>().is_ok());
+ assert!("'a'".parse::<Literal>().is_ok());
+ assert!("\"\n\"".parse::<Literal>().is_ok());
+ assert!("0 1".parse::<Literal>().is_err());
+ assert!(" 0".parse::<Literal>().is_err());
+ assert!("0 ".parse::<Literal>().is_err());
+ assert!("/* comment */0".parse::<Literal>().is_err());
+ assert!("0/* comment */".parse::<Literal>().is_err());
+ assert!("0// comment".parse::<Literal>().is_err());
+ assert!("- 1".parse::<Literal>().is_err());
+ assert!("- 1.0".parse::<Literal>().is_err());
+ assert!("-\"\"".parse::<Literal>().is_err());
+}
+
+#[test]
fn roundtrip() {
fn roundtrip(p: &str) {
println!("parse: {}", p);
let s = p.parse::<TokenStream>().unwrap().to_string();
println!("first: {}", s);
- let s2 = s.to_string().parse::<TokenStream>().unwrap().to_string();
+ let s2 = s.parse::<TokenStream>().unwrap().to_string();
assert_eq!(s, s2);
}
roundtrip("a");
@@ -465,7 +488,7 @@ TokenStream [
#[test]
fn default_tokenstream_is_empty() {
- let default_token_stream: TokenStream = Default::default();
+ let default_token_stream = <TokenStream as Default>::default();
assert!(default_token_stream.is_empty());
}
diff --git a/tests/test_fmt.rs b/tests/test_fmt.rs
index 99a0aee..93dd19e 100644
--- a/tests/test_fmt.rs
+++ b/tests/test_fmt.rs
@@ -1,3 +1,5 @@
+#![allow(clippy::from_iter_instead_of_collect)]
+
use proc_macro2::{Delimiter, Group, Ident, Span, TokenStream, TokenTree};
use std::iter::{self, FromIterator};
@@ -12,7 +14,7 @@ fn test_fmt_group() {
let braces_empty = Group::new(Delimiter::Brace, TokenStream::new());
let braces_nonempty = Group::new(Delimiter::Brace, inner.clone());
let none_empty = Group::new(Delimiter::None, TokenStream::new());
- let none_nonempty = Group::new(Delimiter::None, inner.clone());
+ let none_nonempty = Group::new(Delimiter::None, inner);
// Matches libproc_macro.
assert_eq!("()", parens_empty.to_string());