Allen George | 8b96bfb | 2016-11-02 08:01:08 -0400 | [diff] [blame] | 1 | // Licensed to the Apache Software Foundation (ASF) under one |
| 2 | // or more contributor license agreements. See the NOTICE file |
| 3 | // distributed with this work for additional information |
| 4 | // regarding copyright ownership. The ASF licenses this file |
| 5 | // to you under the Apache License, Version 2.0 (the |
| 6 | // "License"); you may not use this file except in compliance |
| 7 | // with the License. You may obtain a copy of the License at |
| 8 | // |
| 9 | // http://www.apache.org/licenses/LICENSE-2.0 |
| 10 | // |
| 11 | // Unless required by applicable law or agreed to in writing, |
| 12 | // software distributed under the License is distributed on an |
| 13 | // "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| 14 | // KIND, either express or implied. See the License for the |
| 15 | // specific language governing permissions and limitations |
| 16 | // under the License. |
| 17 | |
| 18 | //! Rust runtime library for the Apache Thrift RPC system. |
| 19 | //! |
| 20 | //! This crate implements the components required to build a working |
| 21 | //! Thrift server and client. It is divided into the following modules: |
| 22 | //! |
| 23 | //! 1. errors |
| 24 | //! 2. protocol |
| 25 | //! 3. transport |
| 26 | //! 4. server |
| 27 | //! 5. autogen |
| 28 | //! |
Allen George | 0e22c36 | 2017-01-30 07:15:00 -0500 | [diff] [blame] | 29 | //! The modules are layered as shown in the diagram below. The `autogen'd` |
Allen George | 8b96bfb | 2016-11-02 08:01:08 -0400 | [diff] [blame] | 30 | //! layer is generated by the Thrift compiler's Rust plugin. It uses the |
| 31 | //! types and functions defined in this crate to serialize and deserialize |
| 32 | //! messages and implement RPC. Users interact with these types and services |
Allen George | 0e22c36 | 2017-01-30 07:15:00 -0500 | [diff] [blame] | 33 | //! by writing their own code that uses the auto-generated clients and |
| 34 | //! servers. |
Allen George | 8b96bfb | 2016-11-02 08:01:08 -0400 | [diff] [blame] | 35 | //! |
| 36 | //! ```text |
| 37 | //! +-----------+ |
| 38 | //! | user app | |
| 39 | //! +-----------+ |
| 40 | //! | autogen'd | (uses errors, autogen) |
| 41 | //! +-----------+ |
| 42 | //! | protocol | |
| 43 | //! +-----------+ |
| 44 | //! | transport | |
| 45 | //! +-----------+ |
| 46 | //! ``` |
Zicklag | 70992f1 | 2021-05-08 12:47:13 -0500 | [diff] [blame] | 47 | //! |
| 48 | //! # Tutorial |
| 49 | //! |
| 50 | //! For an example of how to setup a simple client and server using this crate |
| 51 | //! see the [tutorial]. |
| 52 | //! |
| 53 | //! [tutorial]: https://github.com/apache/thrift/tree/master/tutorial/rs |
Allen George | 8b96bfb | 2016-11-02 08:01:08 -0400 | [diff] [blame] | 54 | |
| 55 | #![crate_type = "lib"] |
| 56 | #![doc(test(attr(allow(unused_variables), deny(warnings))))] |
Danny Browning | 77d96c1 | 2019-08-21 13:41:07 -0600 | [diff] [blame] | 57 | #![deny(bare_trait_objects)] |
Allen George | 8b96bfb | 2016-11-02 08:01:08 -0400 | [diff] [blame] | 58 | |
Allen George | 8b96bfb | 2016-11-02 08:01:08 -0400 | [diff] [blame] | 59 | // NOTE: this macro has to be defined before any modules. See: |
| 60 | // https://danielkeep.github.io/quick-intro-to-macros.html#some-more-gotchas |
| 61 | |
| 62 | /// Assert that an expression returning a `Result` is a success. If it is, |
| 63 | /// return the value contained in the result, i.e. `expr.unwrap()`. |
| 64 | #[cfg(test)] |
| 65 | macro_rules! assert_success { |
Allen George | ef7a189 | 2018-12-16 18:01:37 -0500 | [diff] [blame] | 66 | ($e: expr) => {{ |
| 67 | let res = $e; |
| 68 | assert!(res.is_ok()); |
| 69 | res.unwrap() |
| 70 | }}; |
Allen George | 8b96bfb | 2016-11-02 08:01:08 -0400 | [diff] [blame] | 71 | } |
| 72 | |
| 73 | pub mod protocol; |
Jorge C. Leitao | 77afa01 | 2021-08-08 14:51:15 +0000 | [diff] [blame] | 74 | |
| 75 | #[cfg(feature = "server")] |
Allen George | 8b96bfb | 2016-11-02 08:01:08 -0400 | [diff] [blame] | 76 | pub mod server; |
| 77 | pub mod transport; |
| 78 | |
| 79 | mod errors; |
Allen George | b0d1413 | 2020-03-29 11:48:55 -0400 | [diff] [blame] | 80 | pub use crate::errors::*; |
Allen George | 8b96bfb | 2016-11-02 08:01:08 -0400 | [diff] [blame] | 81 | |
| 82 | mod autogen; |
Allen George | b0d1413 | 2020-03-29 11:48:55 -0400 | [diff] [blame] | 83 | pub use crate::autogen::*; |
Allen George | 8b96bfb | 2016-11-02 08:01:08 -0400 | [diff] [blame] | 84 | |
| 85 | /// Result type returned by all runtime library functions. |
| 86 | /// |
| 87 | /// As is convention this is a typedef of `std::result::Result` |
| 88 | /// with `E` defined as the `thrift::Error` type. |
| 89 | pub type Result<T> = std::result::Result<T, self::Error>; |
Danny Browning | ddec431 | 2019-03-08 14:20:41 -0700 | [diff] [blame] | 90 | |
| 91 | // Re-export ordered-float, since it is used by the generator |
Allen George | 55c3e4c | 2021-03-01 23:19:52 -0500 | [diff] [blame] | 92 | // FIXME: check the guidance around type reexports |
| 93 | pub use ordered_float::OrderedFloat; |