Skip to content

Commit

Permalink
Updated docs, fixed labstack#225.
Browse files Browse the repository at this point in the history
Signed-off-by: Vishal Rana <[email protected]>
  • Loading branch information
vishr committed Oct 2, 2015
1 parent c020919 commit 5a71f20
Show file tree
Hide file tree
Showing 15 changed files with 80 additions and 32 deletions.
58 changes: 45 additions & 13 deletions context.go
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ import (
"net/url"

"golang.org/x/net/websocket"
"bytes"
)

type (
Expand Down Expand Up @@ -110,68 +111,99 @@ func (c *Context) Bind(i interface{}) error {

// Render renders a template with data and sends a text/html response with status
// code. Templates can be registered using `Echo.SetRenderer()`.
func (c *Context) Render(code int, name string, data interface{}) error {
func (c *Context) Render(code int, name string, data interface{}) (err error) {
if c.echo.renderer == nil {
return RendererNotRegistered
}
buf := new (bytes.Buffer)
if err = c.echo.renderer.Render(buf, name, data); err != nil {
return
}
c.response.Header().Set(ContentType, TextHTMLCharsetUTF8)
c.response.WriteHeader(code)
return c.echo.renderer.Render(c.response, name, data)
c.response.Write(buf.Bytes())
return
}

// HTML formats according to a format specifier and sends HTML response with
// status code.
func (c *Context) HTML(code int, format string, a ...interface{}) (err error) {
buf := new(bytes.Buffer)
_, err = fmt.Fprintf(buf, format, a...)
if err != nil {
return err
}
c.response.Header().Set(ContentType, TextHTMLCharsetUTF8)
c.response.WriteHeader(code)
_, err = fmt.Fprintf(c.response, format, a...)
c.response.Write(buf.Bytes())
return
}

// String formats according to a format specifier and sends text response with status
// code.
func (c *Context) String(code int, format string, a ...interface{}) (err error) {
buf := new(bytes.Buffer)
_, err = fmt.Fprintf(buf, format, a...)
if err != nil {
return err
}
c.response.Header().Set(ContentType, TextPlain)
c.response.WriteHeader(code)
_, err = fmt.Fprintf(c.response, format, a...)
c.response.Write(buf.Bytes())
return
}

// JSON sends a JSON response with status code.
func (c *Context) JSON(code int, i interface{}) error {
func (c *Context) JSON(code int, i interface{}) (err error) {
b, err := json.Marshal(i)
if err != nil {
return err
}
c.response.Header().Set(ContentType, ApplicationJSONCharsetUTF8)
c.response.WriteHeader(code)
return json.NewEncoder(c.response).Encode(i)
c.response.Write(b)
return
}

// JSONP sends a JSONP response with status code. It uses `callback` to construct
// the JSONP payload.
func (c *Context) JSONP(code int, callback string, i interface{}) (err error) {
b, err := json.Marshal(i)
if err != nil {
return err
}
c.response.Header().Set(ContentType, ApplicationJavaScriptCharsetUTF8)
c.response.WriteHeader(code)
c.response.Write([]byte(callback + "("))
if err = json.NewEncoder(c.response).Encode(i); err == nil {
c.response.Write([]byte(");"))
}
c.response.Write(b)
c.response.Write([]byte(");"))
return
}

// XML sends an XML response with status code.
func (c *Context) XML(code int, i interface{}) error {
func (c *Context) XML(code int, i interface{}) (err error) {
b, err := xml.Marshal(i)
if err != nil {
return err
}
c.response.Header().Set(ContentType, ApplicationXMLCharsetUTF8)
c.response.WriteHeader(code)
c.response.Write([]byte(xml.Header))
return xml.NewEncoder(c.response).Encode(i)
c.response.Write(b)
return
}

// File sends a response with the content of the file. If attachment is true, the
// client is prompted to save the file.
func (c *Context) File(name string, attachment bool) error {
func (c *Context) File(name string, attachment bool) (err error) {
dir, file := path.Split(name)
if attachment {
c.response.Header().Set(ContentDisposition, "attachment; filename="+file)
}
return serveFile(dir, file, c)
if err = serveFile(dir, file, c); err != nil {
c.response.Header().Del(ContentDisposition)
}
return
}

// NoContent sends a response with no body and a status code.
Expand Down
4 changes: 2 additions & 2 deletions context_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -94,7 +94,7 @@ func TestContext(t *testing.T) {
if assert.NoError(t, err) {
assert.Equal(t, http.StatusOK, rec.Code)
assert.Equal(t, ApplicationJSONCharsetUTF8, rec.Header().Get(ContentType))
assert.Equal(t, userJSON+"\n", rec.Body.String())
assert.Equal(t, userJSON, rec.Body.String())
}

// JSONP
Expand All @@ -105,7 +105,7 @@ func TestContext(t *testing.T) {
if assert.NoError(t, err) {
assert.Equal(t, http.StatusOK, rec.Code)
assert.Equal(t, ApplicationJavaScriptCharsetUTF8, rec.Header().Get(ContentType))
assert.Equal(t, callback+"("+userJSON+"\n);", rec.Body.String())
assert.Equal(t, callback+"("+userJSON+");", rec.Body.String())
}

// XML
Expand Down
4 changes: 2 additions & 2 deletions website/config.json
Original file line number Diff line number Diff line change
Expand Up @@ -6,13 +6,13 @@
"menu": {
"main": [{
"Name": "Guide",
"Pre": "<i class='fa fa-heart'></i>",
"Pre": "<i class='fa fa-book'></i>",
"Weight": -110,
"Identifier": "guide",
"URL": "guide"
}, {
"Name": "Recipes",
"Pre": "<i class='fa fa-road'></i>",
"Pre": "<i class='fa fa-code'></i>",
"Weight": -100,
"Identifier": "recipes",
"URL": "recipes"
Expand Down
1 change: 1 addition & 0 deletions website/content/guide/customization.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ title: Customization
menu:
main:
parent: guide
weight: 20
---

### HTTP error handler
Expand Down
1 change: 1 addition & 0 deletions website/content/guide/error-handling.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ title: Error Handling
menu:
main:
parent: guide
weight: 70
---

Echo advocates centralized HTTP error handling by returning `error` from middleware
Expand Down
1 change: 1 addition & 0 deletions website/content/guide/installation.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ title: Installation
menu:
main:
parent: guide
weight: 10
---

Echo has been developed and tested using Go `1.4.x`
Expand Down
1 change: 1 addition & 0 deletions website/content/guide/middleware.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ title: Middleware
menu:
main:
parent: guide
weight: 40
---

Middleware is a function which is chained in the HTTP request-response cycle. Middleware
Expand Down
1 change: 1 addition & 0 deletions website/content/guide/request.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ title: Request
menu:
main:
parent: guide
weight: 50
---

### Path parameter
Expand Down
1 change: 1 addition & 0 deletions website/content/guide/response.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ title: Response
menu:
main:
parent: guide
weight: 60
---

### Template
Expand Down
1 change: 1 addition & 0 deletions website/content/guide/routing.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ title: Routing
menu:
main:
parent: guide
weight: 30
---

Echo's router is [fast, optimized](https://github.com/labstack/echo#benchmark) and
Expand Down
1 change: 1 addition & 0 deletions website/content/recipes/google-app-engine.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
---
title: Google App Engine
draft: true
menu:
main:
parent: recipes
Expand Down
1 change: 1 addition & 0 deletions website/layouts/partials/head.html
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@
<!-- Place favicon.ico in the root directory -->
<link rel="stylesheet" href="//storage.googleapis.com/code.getmdl.io/1.0.5/material.blue-pink.min.css">
<link rel="stylesheet" href="//fonts.googleapis.com/icon?family=Material+Icons">
<link rel="stylesheet" href="//fonts.googleapis.com/css?family=Roboto:300,400,500,700">
<link rel="stylesheet" href="//maxcdn.bootstrapcdn.com/font-awesome/4.4.0/css/font-awesome.min.css">
<link rel="stylesheet" href="{{ .Site.BaseURL }}/styles/monokai.css">
<link rel="stylesheet" href="{{ .Site.BaseURL }}/styles/echo.css">
Expand Down
9 changes: 7 additions & 2 deletions website/layouts/partials/menu.html
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,14 @@
<div>
{{ range .Site.Menus.main }}
{{ if .HasChildren }}
<h4>{{ .Name }}</h4>
<h4>
{{ .Pre }}
{{ .Name }}
</h4>
{{ range .Children }}
<a href="{{ .URL }}">{{ .Name }}</a>
<a href="{{ .URL }}">
{{ .Name }}
</a>
{{ end }}
{{ end }}
{{ end }}
Expand Down
13 changes: 8 additions & 5 deletions website/package.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,10 @@
{
"devDependencies": {
"gulp": "^3.8.11",
"gulp-gh-pages": "^0.5.1",
"gulp-shell": "^0.4.1"
}
"devDependencies": {
"gulp": "^3.8.11",
"gulp-gh-pages": "^0.5.1",
"gulp-shell": "^0.4.1"
},
"dependencies": {
"prismjs": "0.0.1"
}
}
15 changes: 7 additions & 8 deletions website/static/styles/echo.css
Original file line number Diff line number Diff line change
@@ -1,25 +1,24 @@
body {
background-color: #efefef;
}

footer {
padding: 40px 80px !important;
}

code {
font-size: .95em;
padding: 2px 4px;
background: #eee;
color: #4d4d4c;
font-family: Source Code Pro, Monaco, Menlo, Consolas, monospace;
}
a:link {
text-decoration: none;
}

.page-content {
padding: 20px 0;
max-width: 960px;
margin: auto;
}

.page-content header {
padding-bottom: 16px;
}

.menu a {
display: block;
padding: 2px 0
Expand Down

0 comments on commit 5a71f20

Please sign in to comment.