mirror of
https://github.com/actix/actix-website
synced 2024-11-27 18:12:57 +01:00
fix function name in shared mutable state example (#186)
This commit is contained in:
parent
d659d04649
commit
a0ce9f28e2
@ -57,11 +57,11 @@ Internally, [`web::Data`][data] uses `Arc`. Thus, in order to avoid creating two
|
|||||||
|
|
||||||
In the following example, we will write an application with mutable, shared state. First, we define our state and create our handler:
|
In the following example, we will write an application with mutable, shared state. First, we define our state and create our handler:
|
||||||
|
|
||||||
{{< include-example example="application" file="state.rs" section="setup_mutable" >}}
|
{{< include-example example="application" file="mutable_state.rs" section="setup_mutable" >}}
|
||||||
|
|
||||||
and register the data in an `App`:
|
and register the data in an `App`:
|
||||||
|
|
||||||
{{< include-example example="application" file="state.rs" section="make_app_mutable" >}}
|
{{< include-example example="application" file="mutable_state.rs" section="make_app_mutable" >}}
|
||||||
|
|
||||||
## Using an Application Scope to Compose Applications
|
## Using an Application Scope to Compose Applications
|
||||||
|
|
||||||
|
35
examples/application/src/mutable_state.rs
Normal file
35
examples/application/src/mutable_state.rs
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
// <setup_mutable>
|
||||||
|
use actix_web::{web, App, HttpServer};
|
||||||
|
use std::sync::Mutex;
|
||||||
|
|
||||||
|
struct AppStateWithCounter {
|
||||||
|
counter: Mutex<i32>, // <- Mutex is necessary to mutate safely across threads
|
||||||
|
}
|
||||||
|
|
||||||
|
async fn index(data: web::Data<AppStateWithCounter>) -> String {
|
||||||
|
let mut counter = data.counter.lock().unwrap(); // <- get counter's MutexGuard
|
||||||
|
*counter += 1; // <- access counter inside MutexGuard
|
||||||
|
|
||||||
|
format!("Request number: {}", counter) // <- response with count
|
||||||
|
}
|
||||||
|
// </setup_mutable>
|
||||||
|
|
||||||
|
// <make_app_mutable>
|
||||||
|
#[actix_rt::main]
|
||||||
|
async fn main() -> std::io::Result<()> {
|
||||||
|
let counter = web::Data::new(AppStateWithCounter {
|
||||||
|
counter: Mutex::new(0),
|
||||||
|
});
|
||||||
|
|
||||||
|
HttpServer::new(move || {
|
||||||
|
// move counter into the closure
|
||||||
|
App::new()
|
||||||
|
// Note: using app_data instead of data
|
||||||
|
.app_data(counter.clone()) // <- register the created data
|
||||||
|
.route("/", web::get().to(index))
|
||||||
|
})
|
||||||
|
.bind("127.0.0.1:8088")?
|
||||||
|
.run()
|
||||||
|
.await
|
||||||
|
}
|
||||||
|
// </make_app_mutable>
|
@ -14,39 +14,6 @@ async fn index(data: web::Data<AppState>) -> String {
|
|||||||
}
|
}
|
||||||
// </setup>
|
// </setup>
|
||||||
|
|
||||||
// <setup_mutable>
|
|
||||||
struct AppStateWithCounter {
|
|
||||||
counter: Mutex<i32>, // <- Mutex is necessary to mutate safely across threads
|
|
||||||
}
|
|
||||||
|
|
||||||
async fn _index(data: web::Data<AppStateWithCounter>) -> String {
|
|
||||||
let mut counter = data.counter.lock().unwrap(); // <- get counter's MutexGuard
|
|
||||||
*counter += 1; // <- access counter inside MutexGuard
|
|
||||||
|
|
||||||
format!("Request number: {}", counter) // <- response with count
|
|
||||||
}
|
|
||||||
// </setup_mutable>
|
|
||||||
|
|
||||||
// <make_app_mutable>
|
|
||||||
#[actix_rt::main]
|
|
||||||
async fn _main() -> std::io::Result<()> {
|
|
||||||
let counter = web::Data::new(AppStateWithCounter {
|
|
||||||
counter: Mutex::new(0),
|
|
||||||
});
|
|
||||||
|
|
||||||
HttpServer::new(move || {
|
|
||||||
// move counter into the closure
|
|
||||||
App::new()
|
|
||||||
// Note: using app_data instead of data
|
|
||||||
.app_data(counter.clone()) // <- register the created data
|
|
||||||
.route("/", web::get().to(_index))
|
|
||||||
})
|
|
||||||
.bind("127.0.0.1:8088")?
|
|
||||||
.run()
|
|
||||||
.await
|
|
||||||
}
|
|
||||||
// </make_app_mutable>
|
|
||||||
|
|
||||||
// <start_app>
|
// <start_app>
|
||||||
#[actix_rt::main]
|
#[actix_rt::main]
|
||||||
async fn main() -> std::io::Result<()> {
|
async fn main() -> std::io::Result<()> {
|
||||||
|
Loading…
Reference in New Issue
Block a user