mirror of
https://github.com/labstack/echo.git
synced 2025-01-12 01:22:21 +02:00
Priority routes handled ✌️
Signed-off-by: Vishal Rana <vr@labstack.com>
This commit is contained in:
parent
670e21d80e
commit
4c8797f09e
@ -41,9 +41,9 @@ func TestEchoIndex(t *testing.T) {
|
||||
|
||||
func TestEchoStatic(t *testing.T) {
|
||||
e := New()
|
||||
e.Static("/js", "example/public/js")
|
||||
e.Static("/scripts", "example/public/scripts")
|
||||
w := httptest.NewRecorder()
|
||||
r, _ := http.NewRequest(GET, "/js/main.js", nil)
|
||||
r, _ := http.NewRequest(GET, "/scripts/main.js", nil)
|
||||
e.ServeHTTP(w, r)
|
||||
if w.Code != 200 {
|
||||
t.Errorf("status code should be 200, found %d", w.Code)
|
||||
|
@ -83,7 +83,7 @@ func main() {
|
||||
e.Index("public/index.html")
|
||||
|
||||
// Serve static files
|
||||
e.Static("/js", "public/js")
|
||||
e.Static("/scripts", "public/scripts")
|
||||
|
||||
//************//
|
||||
// Routes //
|
||||
@ -97,7 +97,7 @@ func main() {
|
||||
//***************//
|
||||
t := &Template{
|
||||
// Cached templates
|
||||
templates: template.Must(template.ParseFiles("public/tpl/welcome.tpl")),
|
||||
templates: template.Must(template.ParseFiles("public/views/welcome.html")),
|
||||
}
|
||||
e.Renderer(t)
|
||||
e.Get("/welcome", welcome)
|
||||
|
@ -5,7 +5,7 @@
|
||||
<title>Echo</title>
|
||||
</head>
|
||||
<body>
|
||||
Hello, Echo!
|
||||
<script src="/js/main.js"></script>
|
||||
Echo!
|
||||
<script src="/scripts/main.js"></script>
|
||||
</body>
|
||||
</html>
|
||||
|
@ -1 +0,0 @@
|
||||
console.log("Hello, Echo!")
|
1
example/public/scripts/main.js
Normal file
1
example/public/scripts/main.js
Normal file
@ -0,0 +1 @@
|
||||
console.log("Echo!")
|
1
example/public/views/welcome.html
Normal file
1
example/public/views/welcome.html
Normal file
@ -0,0 +1 @@
|
||||
{{define "welcome"}}Hello, {{.}}!{{end}}
|
65
router.go
65
router.go
@ -162,6 +162,7 @@ func (r *router) Find(method, path string, params Params) (h HandlerFunc, echo *
|
||||
search := path
|
||||
n := 0 // Param count
|
||||
|
||||
// Search order static > param > catch-all
|
||||
for {
|
||||
if search == "" || search == cn.prefix {
|
||||
// Found
|
||||
@ -170,45 +171,43 @@ func (r *router) Find(method, path string, params Params) (h HandlerFunc, echo *
|
||||
return
|
||||
}
|
||||
|
||||
pl := len(cn.prefix)
|
||||
l := lcp(search, cn.prefix)
|
||||
search = search[l:]
|
||||
|
||||
if l == pl {
|
||||
search = search[l:]
|
||||
if cn.has == pnode {
|
||||
// Param node
|
||||
cn = cn.edges[0]
|
||||
i, l := 0, len(search)
|
||||
for ; i < l && search[i] != '/'; i++ {
|
||||
}
|
||||
p := params[:n+1]
|
||||
p[n].Name = cn.prefix[1:]
|
||||
p[n].Value = search[:i]
|
||||
n++
|
||||
search = search[i:]
|
||||
} else if cn.has == cnode {
|
||||
// Catch-all node
|
||||
cn = cn.edges[0]
|
||||
p := params[:n+1]
|
||||
p[n].Name = "_name"
|
||||
p[n].Value = search
|
||||
search = "" // End search
|
||||
}
|
||||
|
||||
// Search complete
|
||||
if len(search) == 0 {
|
||||
continue
|
||||
}
|
||||
|
||||
// Static node
|
||||
e := cn.findEdge(search[0])
|
||||
if e != nil {
|
||||
// Go deeper
|
||||
e := cn.findEdge(search[0])
|
||||
if e == nil {
|
||||
// Not found
|
||||
return
|
||||
}
|
||||
cn = e
|
||||
continue
|
||||
}
|
||||
|
||||
// Param node
|
||||
e = cn.findEdge(':')
|
||||
if e != nil {
|
||||
cn = e
|
||||
i, l := 0, len(search)
|
||||
for ; i < l && search[i] != '/'; i++ {
|
||||
}
|
||||
p := params[:n+1]
|
||||
p[n].Name = cn.prefix[1:]
|
||||
p[n].Value = search[:i]
|
||||
n++
|
||||
search = search[i:]
|
||||
continue
|
||||
}
|
||||
|
||||
// Catch-all node
|
||||
e = cn.findEdge('*')
|
||||
if e != nil {
|
||||
cn = e
|
||||
p := params[:n+1]
|
||||
p[n].Name = "_name"
|
||||
p[n].Value = search
|
||||
search = "" // End search
|
||||
continue
|
||||
}
|
||||
|
||||
return
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user