From 224b60b7153ceb0af548ae1cfa4f2101c0b55cc5 Mon Sep 17 00:00:00 2001 From: Julian Hofer Date: Fri, 20 Oct 2023 18:11:45 +0200 Subject: [PATCH] book: Disable playground globally Also remove annotation from code blocks --- book/book.toml | 1 + book/src/actions.md | 24 ++++++++--------- book/src/composite_templates.md | 32 +++++++++++------------ book/src/css.md | 14 +++++----- book/src/g_object_memory_management.md | 14 +++++----- book/src/g_object_properties.md | 18 ++++++------- book/src/g_object_signals.md | 10 +++---- book/src/g_object_subclassing.md | 10 +++---- book/src/g_object_values.md | 10 +++---- book/src/hello_world.md | 6 ++--- book/src/list_widgets.md | 36 +++++++++++++------------- book/src/main_event_loop.md | 10 +++---- book/src/saving_window_state.md | 4 +-- book/src/settings.md | 10 +++---- book/src/todo_1.md | 30 ++++++++++----------- book/src/todo_2.md | 24 ++++++++--------- book/src/widgets.md | 2 +- 17 files changed, 128 insertions(+), 127 deletions(-) diff --git a/book/book.toml b/book/book.toml index 110f3d65ff2c..d0d5d8707b4c 100644 --- a/book/book.toml +++ b/book/book.toml @@ -11,3 +11,4 @@ default-theme = "Rust" git-repository-url = "https://github.com/gtk-rs/gtk4-rs/tree/master/book" git-repository-icon = "fa-github" additional-css = ["theme/style.css"] +playground.runnable = false diff --git a/book/src/actions.md b/book/src/actions.md index 9cf72aa69373..48676f9cea1a 100644 --- a/book/src/actions.md +++ b/book/src/actions.md @@ -37,7 +37,7 @@ If that had not been the case, we would have to add the action group manually vi Filename: listings/actions/2/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/actions/2/main.rs:action_group}} ``` @@ -57,7 +57,7 @@ Let's see how this works. Filename: listings/actions/3/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/actions/3/main.rs:build_ui}} ``` @@ -83,7 +83,7 @@ With [`ButtonBuilder`](https://gtk-rs.org/gtk4-rs/stable/latest/docs/gtk4/builde Filename: listings/actions/4/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/actions/4/main.rs:button_builder}} ``` @@ -101,7 +101,7 @@ We will connect the actions and add them to the window in the `Window::setup_act Filename: listings/actions/5/window/mod.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/actions/5/window/mod.rs:impl_window}} ``` @@ -109,7 +109,7 @@ Finally, `setup_actions` will be called within `constructed`. Filename: listings/actions/5/window/imp.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/actions/5/window/imp.rs:object_impl}} ``` @@ -135,7 +135,7 @@ This means that the caller can expect the boolean state to toggle after activati Filename: listings/actions/6/window/mod.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/actions/6/window/mod.rs:action_button_frame}} ``` @@ -153,7 +153,7 @@ We don't need the action state to implement orientation switching, however it is Filename: listings/actions/6/window/mod.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/actions/6/window/mod.rs:action_orientation}} ``` @@ -255,7 +255,7 @@ Since [`gio::Settings`](https://gtk-rs.org/gtk-rs-core/stable/latest/docs/gio/st Filename: listings/actions/7/window/imp.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/actions/7/window/imp.rs:imp_struct}} ``` @@ -263,7 +263,7 @@ Now we create functions to make it easier to access settings. Filename: listings/actions/7/window/mod.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/actions/7/window/mod.rs:settings}} ``` @@ -273,7 +273,7 @@ We create actions with the[ `create_action`](https://gtk-rs.org/gtk-rs-core/stab Filename: listings/actions/7/window/mod.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/actions/7/window/mod.rs:settings_create_actions}} ``` @@ -285,7 +285,7 @@ For the stateful actions, instead of adding callbacks to their "activate" signal Filename: listings/actions/7/window/mod.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/actions/7/window/mod.rs:bind_settings}} ``` @@ -293,7 +293,7 @@ Finally, we make sure that `bind_settings` is called within `constructed`. Filename: listings/actions/7/window/imp.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/actions/7/window/imp.rs:object_impl}} ``` diff --git a/book/src/composite_templates.md b/book/src/composite_templates.md index 555189e65d98..5c743fc608ce 100644 --- a/book/src/composite_templates.md +++ b/book/src/composite_templates.md @@ -4,7 +4,7 @@ Until now, whenever we constructed pre-defined widgets we relied on the [builder As a reminder, that is how we used it to build our trusty "Hello World!" app. Filename: listings/hello_world/3/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/hello_world/3/main.rs:all}} ``` @@ -57,7 +57,7 @@ Then, we create a `build.rs` at the root of our package with the following conte This will compile the resources whenever we trigger a build with cargo and then statically link our executable to them. Filename: listings/build.rs -```rust ,no_run,noplayground +```rust fn main() { glib_build_tools::compile_resources( &["composite_templates/1/resources"], @@ -71,13 +71,13 @@ Finally, we register and include the resources by calling the macro [`gio::resou In your own apps take care to register the resources before creating the `gtk::Application`. Filename: listings/composite_templates/1/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/composite_templates/1/main.rs}} ``` Within our code we create a custom widget inheriting from `gtk::ApplicationWindow` to make use of our template. Filename: listings/composite_templates/1/window/mod.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/composite_templates/1/window/mod.rs}} ``` @@ -90,7 +90,7 @@ You use it by adding a struct member with the same name as one `id` attribute in This will be useful later, when we want to add a callback to our button. Filename: listings/composite_templates/1/window/imp.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/composite_templates/1/window/imp.rs:object}} ``` @@ -98,7 +98,7 @@ Within the `ObjectSubclass` trait, we make sure that `NAME` corresponds to `clas We also bind and initialize the template in `class_init` and `instance_init`. Filename: listings/composite_templates/1/window/imp.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/composite_templates/1/window/imp.rs:subclass}} ``` @@ -106,7 +106,7 @@ Finally, we connect the callback to the "clicked" signal of `button` within `con The button is easily available thanks to the stored reference in `self`. Filename: listings/composite_templates/1/window/imp.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/composite_templates/1/window/imp.rs:object_impl}} ``` @@ -118,21 +118,21 @@ As usual, we define the implementation struct within `imp.rs`. Note the `NAME` we define here, we will need it later to refer to it in the template. Filename: listings/composite_templates/2/custom_button/imp.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/composite_templates/2/custom_button/imp.rs:imp}} ``` We also define the public struct in `mod.rs`. Filename: listings/composite_templates/2/custom_button/mod.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/composite_templates/2/custom_button/mod.rs:mod}} ``` Since we want to refer to a `CustomButton` now we also have to change the type of the template child to it. Filename: listings/composite_templates/2/window/imp.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/composite_templates/2/window/imp.rs:object}} ``` @@ -162,7 +162,7 @@ It takes a function of type `Fn(&Self)`. This means that `handle_button_clicked` has a single parameter of type `&CustomButton`. Filename: listings/composite_templates/3/window/imp.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/composite_templates/3/window/imp.rs:template_callbacks}} ``` @@ -170,7 +170,7 @@ Then we have to bind the template callbacks with [`bind_template_callbacks`](htt We also need to remove the `button.connect_clicked` callback implemented in `window/imp.rs`. Filename: listings/composite_templates/3/window/imp.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/composite_templates/3/window/imp.rs:subclass}} ``` @@ -178,7 +178,7 @@ We can also access the state of our widget. Let's say we want to manipulate a `number` stored in `imp::Window`. Filename: listings/composite_templates/4/window/imp.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/composite_templates/4/window/imp.rs:object}} ``` @@ -193,7 +193,7 @@ Now we can add `&self` as first parameter to `handle_button_clicked`. This lets us access the state of the window and therefore manipulate `number`. Filename: listings/composite_templates/4/window/imp.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/composite_templates/4/window/imp.rs:template_callbacks}} ``` @@ -203,7 +203,7 @@ Now that we use template callbacks we don't access the template child anymore. Let's remove it. Filename: listings/composite_templates/5/window/imp.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/composite_templates/5/window/imp.rs:object}} ``` @@ -220,7 +220,7 @@ It also ensures that the widget type is registered. Luckily we can also do that by ourselves. Filename: listings/composite_templates/6/window/imp.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/composite_templates/6/window/imp.rs:subclass}} ``` diff --git a/book/src/css.md b/book/src/css.md index ae84b83a2df4..70809e914054 100644 --- a/book/src/css.md +++ b/book/src/css.md @@ -22,7 +22,7 @@ As usual, the widgets are created during the "activate" step. Filename: listings/css/1/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/css/1/main.rs:main}} ``` @@ -71,7 +71,7 @@ Which is why we add the style class `button-1` to the first one. Filename: listings/css/3/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/css/3/main.rs:buttons}} ``` @@ -100,7 +100,7 @@ We set the name of the first one with [`set_widget_name`](https://gtk-rs.org/gtk Filename: listings/css/4/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/css/4/main.rs:buttons}} ``` @@ -127,7 +127,7 @@ Most widgets will document these rules in their documentation under [CSS nodes]( Filename: listings/css/5/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/css/5/main.rs:buttons}} ``` @@ -232,7 +232,7 @@ In our case, the widget `TaskRow` then corresponds to the node `task-row`. Filename: listings/todo/3/task_row/imp.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/todo/3/task_row/imp.rs:object_subclass}} ``` @@ -274,14 +274,14 @@ Additionally, we call `load_css()` in `connect_startup`. Filename: listings/todo/3/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/todo/3/main.rs:connect_startup}} ``` `load_css()` is very similar to the one shown at the beginning of the chapter. However, this time we load styles using `load_from_resource()`. -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/todo/3/main.rs:load_css}} ``` diff --git a/book/src/g_object_memory_management.md b/book/src/g_object_memory_management.md index 082cbb27abb0..60897c3ad10c 100644 --- a/book/src/g_object_memory_management.md +++ b/book/src/g_object_memory_management.md @@ -156,7 +156,7 @@ We need a data type with interior mutability like [`std::cell::Cell`](https://do Filename: listings/g_object_memory_management/1/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/g_object_memory_management/1/main.rs:build_ui}} ``` @@ -172,7 +172,7 @@ we can again use the [`Cell`](https://doc.rust-lang.org/std/cell/struct.Cell.htm Filename: listings/g_object_memory_management/2/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/g_object_memory_management/2/main.rs:callback}} ``` @@ -181,7 +181,7 @@ We can improve that by using the [`glib::clone!`](https://gtk-rs.org/gtk-rs-core Filename: listings/g_object_memory_management/3/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/g_object_memory_management/3/main.rs:callback}} ``` @@ -190,7 +190,7 @@ Therefore, we can pass the buttons the same way to the closure as we did with `n Filename: listings/g_object_memory_management/4/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/g_object_memory_management/4/main.rs:callback}} ``` @@ -207,7 +207,7 @@ Since we want our apps to free unneeded memory, we should use weak references fo Filename: listings/g_object_memory_management/5/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/g_object_memory_management/5/main.rs:callback}} ``` @@ -224,7 +224,7 @@ Who then keeps the buttons alive? Filename: listings/g_object_memory_management/5/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/g_object_memory_management/5/main.rs:box_append}} ``` @@ -232,7 +232,7 @@ When we append the buttons to the `gtk_box`, `gtk_box` keeps a strong reference Filename: listings/g_object_memory_management/5/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/g_object_memory_management/5/main.rs:window_child}} ``` diff --git a/book/src/g_object_properties.md b/book/src/g_object_properties.md index 348bbfd75e05..e500f361dbac 100644 --- a/book/src/g_object_properties.md +++ b/book/src/g_object_properties.md @@ -9,7 +9,7 @@ That is why `gtk-rs` provides corresponding [`is_active`](https://gtk-rs.org/gtk Filename: listings/g_object_properties/1/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/g_object_properties/1/main.rs:switch}} ``` @@ -18,7 +18,7 @@ Let's see how that would look like for two `Switch` instances. Filename: listings/g_object_properties/2/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/g_object_properties/2/main.rs:switches}} ``` @@ -27,7 +27,7 @@ We also want the binding to be bidirectional, so we specify by calling the [`bid Filename: listings/g_object_properties/2/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/g_object_properties/2/main.rs:bind_active}} ``` @@ -51,7 +51,7 @@ It also generates [wrapper methods](https://gtk-rs.org/gtk-rs-core/stable/latest Filename: listings/g_object_properties/3/custom_button/imp.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/g_object_properties/3/custom_button/imp.rs:custom_button}} ``` @@ -62,7 +62,7 @@ Now we don't have to adapt the label in the "clicked" callback anymore. Filename: listings/g_object_properties/3/custom_button/imp.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/g_object_properties/3/custom_button/imp.rs:object_impl}} ``` @@ -70,7 +70,7 @@ We also have to adapt the `clicked` method. Before we modified `number` directly, now we can use the generated wrapper methods `number` and `set_number`. This way the "notify" signal will be emitted, which is necessary for the bindings to work as expected. -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/g_object_properties/3/custom_button/imp.rs:button_impl}} ``` @@ -78,7 +78,7 @@ Let's see what we can do with this by creating two custom buttons. Filename: listings/g_object_properties/3/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/g_object_properties/3/main.rs:buttons}} ``` @@ -87,7 +87,7 @@ By leveraging [`transform_to`](https://gtk-rs.org/gtk-rs-core/stable/latest/docs Filename: listings/g_object_properties/3/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/g_object_properties/3/main.rs:bind_numbers}} ``` Now if we click on one button, the "number" and "label" properties of the other button change as well. @@ -104,7 +104,7 @@ For example like this: Filename: listings/g_object_properties/3/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/g_object_properties/3/main.rs:connect_notify}} ``` diff --git a/book/src/g_object_signals.md b/book/src/g_object_signals.md index 26035f58fe21..218e25b11970 100644 --- a/book/src/g_object_signals.md +++ b/book/src/g_object_signals.md @@ -9,7 +9,7 @@ In our "Hello World" example we [connected](https://gtk-rs.org/gtk4-rs/stable/la Filename: listings/hello_world/3/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/hello_world/3/main.rs:callback}} ``` @@ -17,7 +17,7 @@ If we wanted to, we could have connected to it with the generic [`connect_closur Filename: listings/g_object_signals/1/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/g_object_signals/1/main.rs:callback}} ``` @@ -42,7 +42,7 @@ cargo add once_cell Filename: listings/g_object_signals/2/custom_button/imp.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/g_object_signals/2/custom_button/imp.rs:object_impl}} ``` @@ -57,7 +57,7 @@ After we did that, we set `number` back to 0. Filename: listings/g_object_signals/2/custom_button/imp.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/g_object_signals/2/custom_button/imp.rs:button_impl}} ``` @@ -67,7 +67,7 @@ Whenever we now receive the "max-number-reached" signal, the accompanying number Filename: listings/g_object_signals/2/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/g_object_signals/2/main.rs:signal_handling}} ``` diff --git a/book/src/g_object_subclassing.md b/book/src/g_object_subclassing.md index f2a72e87b3cd..4bf12dd03223 100644 --- a/book/src/g_object_subclassing.md +++ b/book/src/g_object_subclassing.md @@ -7,7 +7,7 @@ First, we need to create an implementation struct that holds the state and overr Filename: listings/g_object_subclassing/1/custom_button/imp.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/g_object_subclassing/1/custom_button/imp.rs}} ``` The description of the subclassing is in `ObjectSubclass`. @@ -22,7 +22,7 @@ Next, we describe the public interface of our custom GObject. Filename: listings/g_object_subclassing/1/custom_button/mod.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/g_object_subclassing/1/custom_button/mod.rs:mod}} ``` @@ -36,7 +36,7 @@ After these steps, nothing is stopping us from replacing `gtk::Button` with our Filename: listings/g_object_subclassing/1/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/g_object_subclassing/1/main.rs}} ``` @@ -55,7 +55,7 @@ So let's make it a bit more interesting! Filename: listings/g_object_subclassing/2/custom_button/imp.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/g_object_subclassing/2/custom_button/imp.rs}} ``` We override `constructed` in `ObjectImpl` so that the label of the button initializes with `number`. @@ -63,7 +63,7 @@ We also override `clicked` in `ButtonImpl` so that every click increases `number Filename: listings/g_object_subclassing/2/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/g_object_subclassing/2/main.rs:activate}} ``` diff --git a/book/src/g_object_values.md b/book/src/g_object_values.md index df28be842481..76ade2c353ba 100644 --- a/book/src/g_object_values.md +++ b/book/src/g_object_values.md @@ -29,7 +29,7 @@ For example, this is how you would use a `Value` representing an `i32`. Filename: listings/g_object_values/1/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/g_object_values/1/main.rs:i32}} ``` @@ -40,7 +40,7 @@ You can still access it the same way as with the `i32` above. Filename: listings/g_object_values/1/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/g_object_values/1/main.rs:string}} ``` @@ -48,7 +48,7 @@ If you want to differentiate between specifying the wrong type and a `Value` rep Filename: listings/g_object_values/1/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/g_object_values/1/main.rs:string_none}} ``` @@ -65,7 +65,7 @@ In the most simple case, converting Rust types to `Variant` and vice-versa is ve Filename: listings/g_object_values/2/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/g_object_values/2/main.rs:i32}} ``` @@ -75,7 +75,7 @@ More examples can be found in the [docs](https://gtk-rs.org/gtk-rs-core/stable/l Filename: listings/g_object_values/2/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/g_object_values/2/main.rs:vec}} ``` diff --git a/book/src/hello_world.md b/book/src/hello_world.md index 6e6c2e4f8e2b..237cacbb798a 100644 --- a/book/src/hello_world.md +++ b/book/src/hello_world.md @@ -8,7 +8,7 @@ Note that we also import the prelude to bring the necessary traits into scope. Filename: listings/hello_world/1/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/hello_world/1/main.rs}} ``` @@ -24,7 +24,7 @@ So let's create a [`gtk::ApplicationWindow`](https://gtk-rs.org/gtk4-rs/stable/l Filename: listings/hello_world/2/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/hello_world/2/main.rs}} ``` That is better! @@ -36,7 +36,7 @@ Also, the name of the chapter suggests that the phrase "Hello World!" will be in Filename: listings/hello_world/3/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/hello_world/3/main.rs:build_ui}} ``` diff --git a/book/src/list_widgets.md b/book/src/list_widgets.md index f33c1d9b6f83..685501f7734c 100644 --- a/book/src/list_widgets.md +++ b/book/src/list_widgets.md @@ -9,7 +9,7 @@ Each label will display an integer starting from 0 and ranging up to 100. Filename: listings/list_widgets/1/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/list_widgets/1/main.rs:list_box}} ``` @@ -19,7 +19,7 @@ Now we can scroll through our elements. Filename: listings/list_widgets/1/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/list_widgets/1/main.rs:scrolled_window}} ``` @@ -54,7 +54,7 @@ So let's create a custom GObject `IntegerObject` that which is initialized with Filename: listings/list_widgets/2/integer_object/mod.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/list_widgets/2/integer_object/mod.rs:integer_object}} # ``` @@ -63,7 +63,7 @@ This number represents the internal state of `IntegerObject`. Filename: listings/list_widgets/2/integer_object/imp.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/list_widgets/2/integer_object/imp.rs:integer_object}} # ``` @@ -74,7 +74,7 @@ Neither `Label` nor any other widget is mentioned here. Filename: listings/list_widgets/2/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/list_widgets/2/main.rs:model}} ``` @@ -85,7 +85,7 @@ We connect to it to create a `Label` for every requested widget. Filename: listings/list_widgets/2/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/list_widgets/2/main.rs:factory_setup}} ``` @@ -93,7 +93,7 @@ In the "bind" step we bind the data in our model to the individual list items. Filename: listings/list_widgets/2/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/list_widgets/2/main.rs:factory_bind}} ``` @@ -103,7 +103,7 @@ Then we pass the model and the factory to the [`ListView`](https://gtk-rs.org/gt Filename: listings/list_widgets/2/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/list_widgets/2/main.rs:selection_list}} ``` @@ -111,7 +111,7 @@ Every `ListView` has to be a direct child of a `ScrolledWindow`, so we are addin Filename: listings/list_widgets/2/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/list_widgets/2/main.rs:scrolled_window}} ``` @@ -125,7 +125,7 @@ For that we first add the method `increase_number` to our `IntegerObject`. Filename: listings/list_widgets/3/integer_object/mod.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/list_widgets/3/integer_object/mod.rs:integer_object}} ``` @@ -133,7 +133,7 @@ In order to interact with our `ListView`, we connect to its "activate" signal. Filename: listings/list_widgets/3/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/list_widgets/3/main.rs:list_view_activate}} ``` @@ -144,7 +144,7 @@ One naive approach would be to bind the properties in the "bind" step of the `Si Filename: listings/list_widgets/3/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/list_widgets/3/main.rs:factory_bind}} ``` @@ -163,7 +163,7 @@ Let's see how the "setup" step now works. Filename: listings/list_widgets/4/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/list_widgets/4/main.rs:factory_setup}} ``` @@ -184,7 +184,7 @@ We do that by passing it to a [`gtk::FilterListModel`](https://gtk-rs.org/gtk4-r Filename: listings/list_widgets/5/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/list_widgets/5/main.rs:filter}} ``` @@ -193,7 +193,7 @@ Now we pass the filtered model to [`gtk::SortListModel`](https://gtk-rs.org/gtk4 Filename: listings/list_widgets/5/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/list_widgets/5/main.rs:sorter}} ``` @@ -201,7 +201,7 @@ To ensure that our filter and sorter get updated when we modify the numbers, we Filename: listings/list_widgets/5/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/list_widgets/5/main.rs:activate}} ``` @@ -223,7 +223,7 @@ First, we add a bunch of strings to our model. Filename: listings/list_widgets/6/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/list_widgets/6/main.rs:string_list}} ``` @@ -235,7 +235,7 @@ Here we can use [`StringObject`](https://gtk-rs.org/gtk4-rs/stable/latest/docs/g Filename: listings/list_widgets/6/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/list_widgets/6/main.rs:factory_setup}} ``` diff --git a/book/src/main_event_loop.md b/book/src/main_event_loop.md index 08c3090cdb80..5add22fca97b 100644 --- a/book/src/main_event_loop.md +++ b/book/src/main_event_loop.md @@ -18,7 +18,7 @@ Let's look at one example. Filename: listings/main_event_loop/1/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/main_event_loop/1/main.rs}} ``` @@ -33,7 +33,7 @@ In order to avoid blocking the main loop we can spawn a new thread with [`gio::s Filename: listings/main_event_loop/2/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/main_event_loop/2/main.rs:callback}} ``` @@ -58,7 +58,7 @@ We want to send a `bool` to inform, whether we want the button to react to click Filename: listings/main_event_loop/3/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/main_event_loop/3/main.rs:callback}} ``` @@ -82,7 +82,7 @@ The converted code looks and behaves very similar to the multi-threaded code. Filename: listings/main_event_loop/4/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/main_event_loop/4/main.rs:callback}} ``` @@ -90,7 +90,7 @@ Since we are single-threaded again, we could even get rid of the channels while Filename: listings/main_event_loop/5/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/main_event_loop/5/main.rs:callback}} ``` diff --git a/book/src/saving_window_state.md b/book/src/saving_window_state.md index f725ac8b5353..94c43161c3c9 100644 --- a/book/src/saving_window_state.md +++ b/book/src/saving_window_state.md @@ -18,7 +18,7 @@ First, we create one and add convenience methods for accessing settings as well Filename: listings/saving_window_state/1/custom_window/mod.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/saving_window_state/1/custom_window/mod.rs:mod}} ``` @@ -34,7 +34,7 @@ We also override the `constructed` and `close_request` methods, where we load or Filename: listings/saving_window_state/1/custom_window/imp.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/saving_window_state/1/custom_window/imp.rs:imp}} ``` diff --git a/book/src/settings.md b/book/src/settings.md index 9f53a4c5da6a..8020e7abd228 100644 --- a/book/src/settings.md +++ b/book/src/settings.md @@ -16,7 +16,7 @@ The `id` is the same application id we used when we created our application. Filename: listings/settings/1/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/settings/1/main.rs:application}} ``` The `path` must start and end with a forward slash character ('/') and must not contain two sequential slash characters. @@ -47,7 +47,7 @@ We initialize the `Settings` object by specifying the application id. Filename: listings/settings/1/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/settings/1/main.rs:settings}} ``` @@ -55,7 +55,7 @@ Then we get the settings key and use it when we create our `Switch`. Filename: listings/settings/1/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/settings/1/main.rs:switch}} ``` @@ -63,7 +63,7 @@ Finally, we assure that the switch state is stored in the settings whenever we c Filename: listings/settings/1/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/settings/1/main.rs:connect_state_set}} ``` @@ -83,7 +83,7 @@ We can remove the [`boolean`](https://gtk-rs.org/gtk-rs-core/stable/latest/docs/ We then bind the setting to the property by specifying the key, object and name of the property. Filename: listings/settings/2/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/settings/2/main.rs:settings_bind}} ``` diff --git a/book/src/todo_1.md b/book/src/todo_1.md index f79190710c81..253f49584bbc 100644 --- a/book/src/todo_1.md +++ b/book/src/todo_1.md @@ -26,7 +26,7 @@ As usual, we have to list all [ancestors](https://docs.gtk.org/gtk4/class.Applic Filename: listings/todo/1/window/mod.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/todo/1/window/mod.rs:glib_wrapper}} ``` @@ -38,7 +38,7 @@ We only have to assure that the `class` attribute of the template in `window.ui` Filename: listings/todo/1/window/imp.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/todo/1/window/imp.rs:struct_and_subclass}} ``` @@ -46,7 +46,7 @@ Filename: listings/todo/1/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/todo/1/main.rs:main}} ``` @@ -78,7 +78,7 @@ This object will store the state of the task consisting of: Filename: listings/todo/1/task_object/mod.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/todo/1/task_object/mod.rs:glib_wrapper_and_new}} ``` @@ -87,7 +87,7 @@ This will be very convenient when saving the state in one of the following chapt Filename: listings/todo/1/task_object/mod.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/todo/1/task_object/mod.rs:task_data}} ``` @@ -97,7 +97,7 @@ For each property we additionally specify the name, the type and which member va Filename: listings/todo/1/task_object/imp.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/todo/1/task_object/imp.rs:struct_and_subclass}} ``` @@ -122,7 +122,7 @@ In the code, we [derive](https://docs.gtk.org/gtk4/class.Box.html#hierarchy) `Ta Filename: listings/todo/1/task_row/mod.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/todo/1/task_row/mod.rs:glib_wrapper}} ``` @@ -133,7 +133,7 @@ Why we need that will become clear as soon as we get to bind the state of `TaskO Filename: listings/todo/1/task_row/imp.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/todo/1/task_row/imp.rs:struct_and_subclass}} ``` @@ -142,7 +142,7 @@ We override the `imp::Window::constructed` in order to set up window contents at Filename: listings/todo/1/window/imp.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/todo/1/window/imp.rs:constructed}} ``` @@ -152,7 +152,7 @@ Then we store a reference to the model in `imp::Window` as well as in `gtk::List Filename: listings/todo/1/window/mod.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/todo/1/window/mod.rs:tasks}} ``` @@ -160,7 +160,7 @@ We also create a method `new_task` which takes the content of the entry, clears Filename: listings/todo/1/window/mod.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/todo/1/window/mod.rs:new_task}} ``` @@ -171,7 +171,7 @@ Finally, the entry will be cleared. Filename: listings/todo/1/window/mod.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/todo/1/window/mod.rs:setup_callbacks}} ``` The list elements for the `gtk::ListView` are produced by a factory. @@ -189,7 +189,7 @@ We will create empty `TaskRow` objects in the "setup" step in `Window::setup_fac Filename: listings/todo/1/window/mod.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/todo/1/window/mod.rs:setup_factory}} ``` @@ -201,7 +201,7 @@ Unbinding will only work if it can access the stored [`glib::Binding`](https://g Filename: listings/todo/1/task_row/mod.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/todo/1/task_row/mod.rs:bind}} ``` @@ -211,7 +211,7 @@ In the end, it clears the vector. Filename: listings/todo/1/task_row/mod.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/todo/1/task_row/mod.rs:unbind}} ``` diff --git a/book/src/todo_2.md b/book/src/todo_2.md index 7ec7ac1ffa2f..89291f377535 100644 --- a/book/src/todo_2.md +++ b/book/src/todo_2.md @@ -83,7 +83,7 @@ Then we add a reference to `settings` to `imp::Window`. Filename: listings/todo/2/window/imp.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/todo/2/window/imp.rs:struct_default}} ``` @@ -91,7 +91,7 @@ Again, we create functions to make it easier to access settings. Filename: listings/todo/2/window/mod.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/todo/2/window/mod.rs:settings}} ``` @@ -101,7 +101,7 @@ We will make use of them in the following snippets. Filename: listings/todo/2/task_object/mod.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/todo/2/task_object/mod.rs:impl}} ``` @@ -111,7 +111,7 @@ We also add an action which allows us to remove done tasks. Filename: listings/todo/2/window/mod.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/todo/2/window/mod.rs:setup_actions}} ``` @@ -123,7 +123,7 @@ If the state is "All" nothing has to be filtered out, so we return `None`. Filename: listings/todo/2/window/mod.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/todo/2/window/mod.rs:filter}} ``` @@ -133,7 +133,7 @@ Whenever the state of the key "filter" changes, we call the method `filter` agai Filename: listings/todo/2/window/mod.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/todo/2/window/mod.rs:setup_tasks}} ``` @@ -143,7 +143,7 @@ Since this has to be done at the application level, `setup_shortcuts` takes a `g Filename: listings/todo/2/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/todo/2/main.rs:main}} ``` @@ -217,7 +217,7 @@ Doing so allows us to derive `Serialize` and `Deserialize` for `TodoData`. Filename: listings/todo/2/task_object/mod.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/todo/2/task_object/mod.rs:task_data}} ``` @@ -227,7 +227,7 @@ Then we return the file path. Filename: listings/todo/2/utils.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/todo/2/utils.rs:data_path}} ``` @@ -237,7 +237,7 @@ Then we serialize the `Vec` and store the data as a json file. Filename: listings/todo/2/window/imp.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/todo/2/window/imp.rs:window_impl}} ``` @@ -279,7 +279,7 @@ It might be the first time that we started the app and therefore there is no for Filename: listings/todo/2/window/mod.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/todo/2/window/mod.rs:restore_data}} ``` @@ -287,7 +287,7 @@ Finally, we make sure that everything is set up in `constructed`. Filename: listings/todo/2/window/imp.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/todo/2/window/imp.rs:object_impl}} ``` diff --git a/book/src/widgets.md b/book/src/widgets.md index c2a3ffe59ec3..8f3e30999ed5 100644 --- a/book/src/widgets.md +++ b/book/src/widgets.md @@ -31,6 +31,6 @@ And indeed, `ButtonExt` includes the method [`connect_clicked`](https://gtk-rs.o Filename: listings/hello_world/3/main.rs -```rust ,no_run,noplayground +```rust {{#rustdoc_include ../listings/hello_world/3/main.rs:button}} ```