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 | //! ``` |
| 47 | |
| 48 | #![crate_type = "lib"] |
| 49 | #![doc(test(attr(allow(unused_variables), deny(warnings))))] |
Danny Browning | 77d96c1 | 2019-08-21 13:41:07 -0600 | [diff] [blame] | 50 | #![deny(bare_trait_objects)] |
Allen George | 8b96bfb | 2016-11-02 08:01:08 -0400 | [diff] [blame] | 51 | |
Allen George | 8b96bfb | 2016-11-02 08:01:08 -0400 | [diff] [blame] | 52 | // NOTE: this macro has to be defined before any modules. See: |
| 53 | // https://danielkeep.github.io/quick-intro-to-macros.html#some-more-gotchas |
| 54 | |
| 55 | /// Assert that an expression returning a `Result` is a success. If it is, |
| 56 | /// return the value contained in the result, i.e. `expr.unwrap()`. |
| 57 | #[cfg(test)] |
| 58 | macro_rules! assert_success { |
Allen George | ef7a189 | 2018-12-16 18:01:37 -0500 | [diff] [blame] | 59 | ($e: expr) => {{ |
| 60 | let res = $e; |
| 61 | assert!(res.is_ok()); |
| 62 | res.unwrap() |
| 63 | }}; |
Allen George | 8b96bfb | 2016-11-02 08:01:08 -0400 | [diff] [blame] | 64 | } |
| 65 | |
| 66 | pub mod protocol; |
| 67 | pub mod server; |
| 68 | pub mod transport; |
| 69 | |
| 70 | mod errors; |
Allen George | b0d1413 | 2020-03-29 11:48:55 -0400 | [diff] [blame] | 71 | pub use crate::errors::*; |
Allen George | 8b96bfb | 2016-11-02 08:01:08 -0400 | [diff] [blame] | 72 | |
| 73 | mod autogen; |
Allen George | b0d1413 | 2020-03-29 11:48:55 -0400 | [diff] [blame] | 74 | pub use crate::autogen::*; |
Allen George | 8b96bfb | 2016-11-02 08:01:08 -0400 | [diff] [blame] | 75 | |
| 76 | /// Result type returned by all runtime library functions. |
| 77 | /// |
| 78 | /// As is convention this is a typedef of `std::result::Result` |
| 79 | /// with `E` defined as the `thrift::Error` type. |
| 80 | pub type Result<T> = std::result::Result<T, self::Error>; |
Danny Browning | ddec431 | 2019-03-08 14:20:41 -0700 | [diff] [blame] | 81 | |
| 82 | // Re-export ordered-float, since it is used by the generator |
Allen George | 55c3e4c | 2021-03-01 23:19:52 -0500 | [diff] [blame] | 83 | // FIXME: check the guidance around type reexports |
| 84 | pub use ordered_float::OrderedFloat; |