20 releases

0.9.5 Nov 29, 2024
0.9.3 Jun 14, 2024
0.9.2 Feb 5, 2024
0.9.1 Nov 27, 2023
0.7.0 Nov 17, 2022

#559 in Web programming

Download history 2227/week @ 2024-09-18 1707/week @ 2024-09-25 1281/week @ 2024-10-02 1039/week @ 2024-10-09 1237/week @ 2024-10-16 1929/week @ 2024-10-23 1080/week @ 2024-10-30 1589/week @ 2024-11-06 1223/week @ 2024-11-13 1481/week @ 2024-11-20 1476/week @ 2024-11-27 1474/week @ 2024-12-04 1725/week @ 2024-12-11 1146/week @ 2024-12-18 320/week @ 2024-12-25 1458/week @ 2025-01-01

4,889 downloads per month
Used in 16 crates (12 directly)

MIT/Apache

33KB
583 lines

tower-livereload

Build Status Crates.io Lib.rs Documentation

A middleware for browser reloading, built on top of tower.

Example

Note that axum is only used as an example here, pretty much any Rust HTTP library or framework will be compatible!

use axum::{response::Html, routing::get, Router};
use tower_livereload::LiveReloadLayer;

#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
    let app = Router::new()
        .route("/", get(|| async { Html("<h1>Wow, such webdev</h1>") }))
        .layer(LiveReloadLayer::new());

    let listener = tokio::net::TcpListener::bind("0.0.0.0:3030").await?;
    axum::serve(listener, app).await?;

    Ok(())
}

If you continuously rebuild and rerun this example e.g. using watchexec, you should see your browser reload whenever the code is changed.

More examples can be found on GitHub under examples.

Manual reload

With the Reloader utility, it is possible to reload your web browser entirely using hooks from Rust code. See this example on GitHub for pointers on how to implement a self-contained live-reloading static server.

Ecosystem compatibility

tower-livereload has been built from the ground up to provide the highest amount of ecosystem compatibility.

The provided middleware uses the http and http_body crates as its HTTP abstractions. That means it is compatible with any library or framework that also uses those crates, such as hyper, axum, tonic, and warp.

Heuristics

To provide LiveReload functionality, we have to inject code into HTML web pages. To determine whether a page is injectable, some header-based heuristics are used. In particular, Content-Type has to start with text/html and Content-Encoding must not be set.

If LiveReload is not working for some of your pages, ensure that these heuristics apply to your responses. In particular, if you use middleware to compress your HTML, ensure that the LiveReload middleware is applied before your compression middleware.

License

tower-livereload is free and open source software distributed under the terms of either the MIT or the Apache 2.0 license, at your option.

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Dependencies

~3–8.5MB
~64K SLoC