mirror of
https://github.com/gohugoio/hugo.git
synced 2025-04-07 01:02:31 +00:00
output: Add output type
This commit is contained in:
parent
c4989c39f1
commit
d3d2c63dd9
6 changed files with 126 additions and 9 deletions
|
@ -1886,8 +1886,8 @@ func kindFromFilename(filename string) string {
|
||||||
|
|
||||||
// TODO(bep) output
|
// TODO(bep) output
|
||||||
var (
|
var (
|
||||||
mediaTypesWithRSS = media.Types{media.HtmlType, media.RSSType}
|
mediaTypesWithRSS = media.Types{media.HTMLType, media.RSSType}
|
||||||
mediaTypesHTML = media.Types{media.HtmlType}
|
mediaTypesHTML = media.Types{media.HTMLType}
|
||||||
)
|
)
|
||||||
|
|
||||||
func (p *Page) setValuesForKind(s *Site) {
|
func (p *Page) setValuesForKind(s *Site) {
|
||||||
|
|
|
@ -67,7 +67,7 @@ func pageRenderer(s *Site, pages <-chan *Page, results chan<- error, wg *sync.Wa
|
||||||
for _, mediaType := range p.mediaTypes {
|
for _, mediaType := range p.mediaTypes {
|
||||||
switch mediaType {
|
switch mediaType {
|
||||||
|
|
||||||
case media.HtmlType:
|
case media.HTMLType:
|
||||||
targetPath := p.TargetPath()
|
targetPath := p.TargetPath()
|
||||||
|
|
||||||
layouts := p.layouts()
|
layouts := p.layouts()
|
||||||
|
|
|
@ -35,18 +35,18 @@ type Type struct {
|
||||||
// default media types. These can be overridden by the user in the configuration,
|
// default media types. These can be overridden by the user in the configuration,
|
||||||
// by defining a media type with the same Key.
|
// by defining a media type with the same Key.
|
||||||
func (m Type) Key() string {
|
func (m Type) Key() string {
|
||||||
|
return fmt.Sprintf("%s/%s", m.Type, m.SubType)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m Type) String() string {
|
||||||
if m.Suffix != "" {
|
if m.Suffix != "" {
|
||||||
return fmt.Sprintf("%s/%s+%s", m.Type, m.SubType, m.Suffix)
|
return fmt.Sprintf("%s/%s+%s", m.Type, m.SubType, m.Suffix)
|
||||||
}
|
}
|
||||||
return fmt.Sprintf("%s/%s", m.Type, m.SubType)
|
return fmt.Sprintf("%s/%s", m.Type, m.SubType)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m Type) String() string {
|
|
||||||
return m.Key()
|
|
||||||
}
|
|
||||||
|
|
||||||
var (
|
var (
|
||||||
HtmlType = Type{"text", "html", "html"}
|
HTMLType = Type{"text", "html", "html"}
|
||||||
RSSType = Type{"application", "rss", "xml"}
|
RSSType = Type{"application", "rss", "xml"}
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -54,8 +54,9 @@ var (
|
||||||
// These can be ovverriden, and more added if needed, in the Hugo configuration file.
|
// These can be ovverriden, and more added if needed, in the Hugo configuration file.
|
||||||
// The final media type set set will also be added as extensions to mime so
|
// The final media type set set will also be added as extensions to mime so
|
||||||
// they will be recognised by the built-in server in Hugo.
|
// they will be recognised by the built-in server in Hugo.
|
||||||
|
// TODO(bep) output remove
|
||||||
var DefaultMediaTypes = Types{
|
var DefaultMediaTypes = Types{
|
||||||
HtmlType,
|
HTMLType,
|
||||||
RSSType,
|
RSSType,
|
||||||
|
|
||||||
// TODO(bep) output
|
// TODO(bep) output
|
37
media/mediaType_test.go
Normal file
37
media/mediaType_test.go
Normal file
|
@ -0,0 +1,37 @@
|
||||||
|
// Copyright 2017-present The Hugo Authors. All rights reserved.
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
|
||||||
|
package media
|
||||||
|
|
||||||
|
import (
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/stretchr/testify/require"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestDefaultTypes(t *testing.T) {
|
||||||
|
require.Equal(t, "text", HTMLType.Type)
|
||||||
|
require.Equal(t, "html", HTMLType.SubType)
|
||||||
|
require.Equal(t, "html", HTMLType.Suffix)
|
||||||
|
|
||||||
|
require.Equal(t, "text/html", HTMLType.Key())
|
||||||
|
require.Equal(t, "text/html+html", HTMLType.String())
|
||||||
|
|
||||||
|
require.Equal(t, "application", RSSType.Type)
|
||||||
|
require.Equal(t, "rss", RSSType.SubType)
|
||||||
|
require.Equal(t, "xml", RSSType.Suffix)
|
||||||
|
|
||||||
|
require.Equal(t, "application/rss", RSSType.Key())
|
||||||
|
require.Equal(t, "application/rss+xml", RSSType.String())
|
||||||
|
|
||||||
|
}
|
46
output/outputType.go
Normal file
46
output/outputType.go
Normal file
|
@ -0,0 +1,46 @@
|
||||||
|
// Copyright 2017-present The Hugo Authors. All rights reserved.
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
|
||||||
|
package output
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/spf13/hugo/media"
|
||||||
|
)
|
||||||
|
|
||||||
|
var (
|
||||||
|
HTMLType = Type{
|
||||||
|
Name: "HTML",
|
||||||
|
MediaType: media.HTMLType,
|
||||||
|
}
|
||||||
|
|
||||||
|
RSSType = Type{
|
||||||
|
Name: "RSS",
|
||||||
|
MediaType: media.RSSType,
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
// Type represents an output represenation, usually to a file on disk.
|
||||||
|
type Type struct {
|
||||||
|
// The Name is used as an identifier. Internal output types (i.e. HTML and RSS)
|
||||||
|
// can be overridden by providing a new definition for those types.
|
||||||
|
Name string
|
||||||
|
|
||||||
|
MediaType media.Type
|
||||||
|
|
||||||
|
// Must be set to a value when there are two or more conflicting mediatype for the same resource.
|
||||||
|
Path string
|
||||||
|
|
||||||
|
// IsPlainText decides whether to use text/template or html/template
|
||||||
|
// as template parser.
|
||||||
|
IsPlainText bool
|
||||||
|
}
|
33
output/outputType_test.go
Normal file
33
output/outputType_test.go
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
// Copyright 2017-present The Hugo Authors. All rights reserved.
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
|
||||||
|
package output
|
||||||
|
|
||||||
|
import (
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/spf13/hugo/media"
|
||||||
|
"github.com/stretchr/testify/require"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestDefaultTypes(t *testing.T) {
|
||||||
|
require.Equal(t, "HTML", HTMLType.Name)
|
||||||
|
require.Equal(t, media.HTMLType, HTMLType.MediaType)
|
||||||
|
require.Empty(t, HTMLType.Path)
|
||||||
|
require.False(t, HTMLType.IsPlainText)
|
||||||
|
|
||||||
|
require.Equal(t, "RSS", RSSType.Name)
|
||||||
|
require.Equal(t, media.RSSType, RSSType.MediaType)
|
||||||
|
require.Empty(t, RSSType.Path)
|
||||||
|
require.False(t, RSSType.IsPlainText)
|
||||||
|
}
|
Loading…
Add table
Reference in a new issue