1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
/*
* Copyright 2019 The Starlark in Rust Authors.
* Copyright (c) Facebook, Inc. and its affiliates.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* https://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
//! A type [`StarlarkAny`] which can cheaply wrap any Rust value into a [`Value`].
//!
//! This is intended to be a low cost way to quickly wrap Rust types without much boilerplate.
//! For more advanced uses you should define an instance of [`StarlarkValue`].
//!
//! To use this type, usually you will return a [`StarlarkAny`] from a module function,
//! and consume it in another. As an example, we can cheaply wrap the
//! [`Duration`](std::time::Duration) type.
//!
//! ```
//! #[macro_use]
//! extern crate starlark;
//! # fn main() {
//! use std::fmt;
//! use std::time::Instant;
//!
//! use starlark::assert::Assert;
//! use starlark::environment::GlobalsBuilder;
//! use starlark::values::any::StarlarkAny;
//! use starlark::values::Value;
//!
//! #[derive(Debug)]
//! struct MyInstant(Instant);
//!
//! #[starlark_module]
//! fn globals(builder: &mut GlobalsBuilder) {
//! fn start() -> anyhow::Result<StarlarkAny<MyInstant>> {
//! Ok(StarlarkAny::new(MyInstant(Instant::now())))
//! }
//!
//! fn elapsed(x: Value) -> anyhow::Result<String> {
//! Ok(StarlarkAny::<MyInstant>::get(x)
//! .unwrap()
//! .0
//! .elapsed()
//! .as_secs_f64()
//! .to_string())
//! }
//! }
//!
//! let mut a = Assert::new();
//! a.globals_add(globals);
//! a.pass(
//! r#"
//! instant = start()
//! print(elapsed(instant))
//! "#,
//! );
//! # }
//! ```
use fmt;
use Debug;
use Allocative;
use starlark_value;
use NoSerialize;
use crate as starlark;
use crateProvidesStaticType;
use crateAllocValue;
use crateHeap;
use crateStarlarkValue;
use crateValue;
use crateValueLike;
/// A type that can be passed around as a Starlark [`Value`], but in most
/// ways is uninteresting/opaque to Starlark. Constructed with
/// [`new`](StarlarkAny::new) and decomposed with [`get`](StarlarkAny::get).
///
/// This is version for "simple" values (not requiring trace during GC).
/// For "complex" version check
/// [`StarlarkAnyComplex`](crate::values::types::any_complex::StarlarkAnyComplex).
] // TODO(nga): do not skip.
pub T,
);