mirror of
https://github.com/gohugoio/hugo.git
synced 2024-11-07 20:30:36 -05: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
|
||||
var (
|
||||
mediaTypesWithRSS = media.Types{media.HtmlType, media.RSSType}
|
||||
mediaTypesHTML = media.Types{media.HtmlType}
|
||||
mediaTypesWithRSS = media.Types{media.HTMLType, media.RSSType}
|
||||
mediaTypesHTML = media.Types{media.HTMLType}
|
||||
)
|
||||
|
||||
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 {
|
||||
switch mediaType {
|
||||
|
||||
case media.HtmlType:
|
||||
case media.HTMLType:
|
||||
targetPath := p.TargetPath()
|
||||
|
||||
layouts := p.layouts()
|
||||
|
|
|
@ -35,18 +35,18 @@ type Type struct {
|
|||
// default media types. These can be overridden by the user in the configuration,
|
||||
// by defining a media type with the same Key.
|
||||
func (m Type) Key() string {
|
||||
return fmt.Sprintf("%s/%s", m.Type, m.SubType)
|
||||
}
|
||||
|
||||
func (m Type) String() string {
|
||||
if m.Suffix != "" {
|
||||
return fmt.Sprintf("%s/%s+%s", m.Type, m.SubType, m.Suffix)
|
||||
}
|
||||
return fmt.Sprintf("%s/%s", m.Type, m.SubType)
|
||||
}
|
||||
|
||||
func (m Type) String() string {
|
||||
return m.Key()
|
||||
}
|
||||
|
||||
var (
|
||||
HtmlType = Type{"text", "html", "html"}
|
||||
HTMLType = Type{"text", "html", "html"}
|
||||
RSSType = Type{"application", "rss", "xml"}
|
||||
)
|
||||
|
||||
|
@ -54,8 +54,9 @@ var (
|
|||
// 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
|
||||
// they will be recognised by the built-in server in Hugo.
|
||||
// TODO(bep) output remove
|
||||
var DefaultMediaTypes = Types{
|
||||
HtmlType,
|
||||
HTMLType,
|
||||
RSSType,
|
||||
|
||||
// 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…
Reference in a new issue