mirror of
https://github.com/rwf2/Rocket.git
synced 2025-01-26 19:32:08 +00:00
51ed332127
This commit modifies request routing in a backwards incompatible manner. The change is summarized as: trailing slashes are now significant and never transparently disregarded. This has the following implications, all representing behavior that differs from that before this change: * Route URIs with trailing slashes (`/foo/`, `/<a>/`) are legal. * A request `/foo/` is routed to route `/foo/` but not `/foo`. * Similarly, a request `/bar/` is routed to `/<a>/` but not `/<a>`. * A request `/bar/foo` is not routed to `/<a>/<b>/<c..>`. A new `AdHoc::uri_normalizer()` fairing was added that recovers the previous behavior. In addition to the above, the `Options::NormalizeDirs` `FileServer` option is now enabled by default to remain consistent with the above changes and reduce breaking changes at the `FileServer` level.
183 lines
5.0 KiB
Plaintext
183 lines
5.0 KiB
Plaintext
error: invalid route URI: expected token '/' but found 'a' at index 0
|
|
--- help: expected URI in origin form: "/path/<param>"
|
|
--> tests/ui-fail-stable/route-path-bad-syntax.rs:5:7
|
|
|
|
|
5 | #[get("a")]
|
|
| ^^^
|
|
|
|
error: invalid route URI: unexpected EOF: expected token '/' at index 0
|
|
--- help: expected URI in origin form: "/path/<param>"
|
|
--> tests/ui-fail-stable/route-path-bad-syntax.rs:8:7
|
|
|
|
|
8 | #[get("")]
|
|
| ^^
|
|
|
|
error: invalid route URI: expected token '/' but found 'a' at index 0
|
|
--- help: expected URI in origin form: "/path/<param>"
|
|
--> tests/ui-fail-stable/route-path-bad-syntax.rs:11:7
|
|
|
|
|
11 | #[get("a/b/c")]
|
|
| ^^^^^^^
|
|
|
|
error: route URIs cannot contain empty segments
|
|
--- note: expected "/a/b", found "/a///b"
|
|
--> tests/ui-fail-stable/route-path-bad-syntax.rs:14:7
|
|
|
|
|
14 | #[get("/a///b")]
|
|
| ^^^^^^^^
|
|
|
|
error: route URIs cannot contain empty segments
|
|
--- note: expected "/?bat", found "/?bat&&"
|
|
--> tests/ui-fail-stable/route-path-bad-syntax.rs:17:7
|
|
|
|
|
17 | #[get("/?bat&&")]
|
|
| ^^^^^^^^^
|
|
|
|
error: route URIs cannot contain empty segments
|
|
--- note: expected "/?bat", found "/?bat&&"
|
|
--> tests/ui-fail-stable/route-path-bad-syntax.rs:20:7
|
|
|
|
|
20 | #[get("/?bat&&")]
|
|
| ^^^^^^^^^
|
|
|
|
error: route URIs cannot contain empty segments
|
|
--- note: expected "/a/b/", found "/a/b//"
|
|
--> tests/ui-fail-stable/route-path-bad-syntax.rs:23:7
|
|
|
|
|
23 | #[get("/a/b//")]
|
|
| ^^^^^^^^
|
|
|
|
error: unused parameter
|
|
--> tests/ui-fail-stable/route-path-bad-syntax.rs:42:7
|
|
|
|
|
42 | #[get("/<name>")]
|
|
| ^^^^^^^^^
|
|
|
|
error: [note] expected argument named `name` here
|
|
--> tests/ui-fail-stable/route-path-bad-syntax.rs:43:6
|
|
|
|
|
43 | fn h0(_name: usize) {}
|
|
| ^^^^^^^^^^^^^^
|
|
|
|
error: unused parameter
|
|
--> tests/ui-fail-stable/route-path-bad-syntax.rs:45:7
|
|
|
|
|
45 | #[get("/a?<r>")]
|
|
| ^^^^^^^^
|
|
|
|
error: [note] expected argument named `r` here
|
|
--> tests/ui-fail-stable/route-path-bad-syntax.rs:46:6
|
|
|
|
|
46 | fn h1() {}
|
|
| ^^
|
|
|
|
error: unused parameter
|
|
--> tests/ui-fail-stable/route-path-bad-syntax.rs:48:21
|
|
|
|
|
48 | #[post("/a", data = "<test>")]
|
|
| ^^^^^^^^
|
|
|
|
error: [note] expected argument named `test` here
|
|
--> tests/ui-fail-stable/route-path-bad-syntax.rs:49:6
|
|
|
|
|
49 | fn h2() {}
|
|
| ^^
|
|
|
|
error: unused parameter
|
|
--> tests/ui-fail-stable/route-path-bad-syntax.rs:51:7
|
|
|
|
|
51 | #[get("/<_r>")]
|
|
| ^^^^^^^
|
|
|
|
error: [note] expected argument named `_r` here
|
|
--> tests/ui-fail-stable/route-path-bad-syntax.rs:52:6
|
|
|
|
|
52 | fn h3() {}
|
|
| ^^
|
|
|
|
error: unused parameter
|
|
--> tests/ui-fail-stable/route-path-bad-syntax.rs:54:7
|
|
|
|
|
54 | #[get("/<_r>/<b>")]
|
|
| ^^^^^^^^^^^
|
|
|
|
error: [note] expected argument named `b` here
|
|
--> tests/ui-fail-stable/route-path-bad-syntax.rs:55:6
|
|
|
|
|
55 | fn h4() {}
|
|
| ^^
|
|
|
|
error: invalid identifier: `foo_.`
|
|
--- help: dynamic parameters must be valid identifiers
|
|
--- help: did you mean `<foo_>`?
|
|
--> tests/ui-fail-stable/route-path-bad-syntax.rs:60:7
|
|
|
|
|
60 | #[get("/<foo_.>")]
|
|
| ^^^^^^^^^^
|
|
|
|
error: invalid identifier: `foo*`
|
|
--- help: dynamic parameters must be valid identifiers
|
|
--- help: did you mean `<foo>`?
|
|
--> tests/ui-fail-stable/route-path-bad-syntax.rs:63:7
|
|
|
|
|
63 | #[get("/<foo*>")]
|
|
| ^^^^^^^^^
|
|
|
|
error: invalid identifier: `!`
|
|
--- help: dynamic parameters must be valid identifiers
|
|
--- help: did you mean `<param>`?
|
|
--> tests/ui-fail-stable/route-path-bad-syntax.rs:66:7
|
|
|
|
|
66 | #[get("/<!>")]
|
|
| ^^^^^^
|
|
|
|
error: invalid identifier: `name>:<id`
|
|
--- help: dynamic parameters must be valid identifiers
|
|
--- help: did you mean `<nameid>`?
|
|
--> tests/ui-fail-stable/route-path-bad-syntax.rs:69:7
|
|
|
|
|
69 | #[get("/<name>:<id>")]
|
|
| ^^^^^^^^^^^^^^
|
|
|
|
error: unexpected static parameter
|
|
--- help: parameter must be dynamic: `<foo>`
|
|
--> tests/ui-fail-stable/route-path-bad-syntax.rs:74:19
|
|
|
|
|
74 | #[get("/", data = "foo")]
|
|
| ^^^^^
|
|
|
|
error: parameter cannot be trailing
|
|
--- help: did you mean `<foo>`?
|
|
--> tests/ui-fail-stable/route-path-bad-syntax.rs:77:19
|
|
|
|
|
77 | #[get("/", data = "<foo..>")]
|
|
| ^^^^^^^^^
|
|
|
|
error: unexpected static parameter
|
|
--- help: parameter must be dynamic: `<foo>`
|
|
--> tests/ui-fail-stable/route-path-bad-syntax.rs:80:19
|
|
|
|
|
80 | #[get("/", data = "<foo")]
|
|
| ^^^^^^
|
|
|
|
error: invalid identifier: `test `
|
|
--- help: dynamic parameters must be valid identifiers
|
|
--- help: did you mean `<test>`?
|
|
--> tests/ui-fail-stable/route-path-bad-syntax.rs:83:19
|
|
|
|
|
83 | #[get("/", data = "<test >")]
|
|
| ^^^^^^^^^
|
|
|
|
error: handler arguments must be named
|
|
--- help: to name an ignored handler argument, use `_name`
|
|
--> tests/ui-fail-stable/route-path-bad-syntax.rs:89:7
|
|
|
|
|
89 | fn k0(_: usize) {}
|
|
| ^
|
|
|
|
error: parameters cannot be empty
|
|
--> tests/ui-fail-stable/route-path-bad-syntax.rs:93:7
|
|
|
|
|
93 | #[get("/<>")]
|
|
| ^^^^^
|