mirror of
https://gitee.com/gitea/gitea
synced 2025-11-26 19:30:28 +08:00
Started to integrate options bindata and accessors
This commit is contained in:
1
.gitignore
vendored
1
.gitignore
vendored
@@ -28,6 +28,7 @@ _testmain.go
|
|||||||
|
|
||||||
coverage.out
|
coverage.out
|
||||||
|
|
||||||
|
/modules/options/bindata.go
|
||||||
/modules/public/bindata.go
|
/modules/public/bindata.go
|
||||||
|
|
||||||
*.db
|
*.db
|
||||||
|
|||||||
94
modules/options/dynamic.go
Normal file
94
modules/options/dynamic.go
Normal file
@@ -0,0 +1,94 @@
|
|||||||
|
// +build !bindata
|
||||||
|
|
||||||
|
// Copyright 2016 The Gitea Authors. All rights reserved.
|
||||||
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
|
package options
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"io/ioutil"
|
||||||
|
"path"
|
||||||
|
|
||||||
|
"code.gitea.io/gitea/modules/setting"
|
||||||
|
"github.com/Unknwon/com"
|
||||||
|
)
|
||||||
|
|
||||||
|
var (
|
||||||
|
directories = make(directorySet)
|
||||||
|
)
|
||||||
|
|
||||||
|
// Dir returns all files from static or custom directory.
|
||||||
|
func Dir(name string) ([]string, error) {
|
||||||
|
if directories.Filled(name) {
|
||||||
|
return directories.Get(name), nil
|
||||||
|
}
|
||||||
|
|
||||||
|
var (
|
||||||
|
result []string
|
||||||
|
)
|
||||||
|
|
||||||
|
customDir := path.Join(setting.CustomPath, "options", name)
|
||||||
|
|
||||||
|
if com.IsDir(customDir) {
|
||||||
|
files, err := com.StatDir(customDir, true)
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
return []string{}, fmt.Errorf("Failed to read custom directory. %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
result = append(result, files...)
|
||||||
|
}
|
||||||
|
|
||||||
|
staticDir := path.Join(setting.StaticRootPath, "options", name)
|
||||||
|
|
||||||
|
if com.IsDir(staticDir) {
|
||||||
|
files, err := com.StatDir(staticDir, true)
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
return []string{}, fmt.Errorf("Failed to read static directory. %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
result = append(result, files...)
|
||||||
|
}
|
||||||
|
|
||||||
|
return directories.AddAndGet(name, result), nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// Locale reads the content of a specific locale from static or custom path.
|
||||||
|
func Locale(name string) ([]byte, error) {
|
||||||
|
return fileFromDir(path.Join("locale", name))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Readme reads the content of a specific readme from static or custom path.
|
||||||
|
func Readme(name string) ([]byte, error) {
|
||||||
|
return fileFromDir(path.Join("readme", name))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Gitignore reads the content of a specific gitignore from static or custom path.
|
||||||
|
func Gitignore(name string) ([]byte, error) {
|
||||||
|
return fileFromDir(path.Join("gitignore", name))
|
||||||
|
}
|
||||||
|
|
||||||
|
// License reads the content of a specific license from static or custom path.
|
||||||
|
func License(name string) ([]byte, error) {
|
||||||
|
return fileFromDir(path.Join("license", name))
|
||||||
|
}
|
||||||
|
|
||||||
|
// fileFromDir is a helper to read files from static or custom path.
|
||||||
|
func fileFromDir(name string) ([]byte, error) {
|
||||||
|
customPath := path.Join(setting.CustomPath, "options", name)
|
||||||
|
|
||||||
|
if com.IsFile(customPath) {
|
||||||
|
return ioutil.ReadFile(customPath)
|
||||||
|
}
|
||||||
|
|
||||||
|
staticPath := path.Join(setting.StaticRootPath, "options", name)
|
||||||
|
|
||||||
|
if com.IsFile(staticPath) {
|
||||||
|
return ioutil.ReadFile(staticPath)
|
||||||
|
}
|
||||||
|
|
||||||
|
return []byte{}, fmt.Errorf("Asset file does not exist: %s", name)
|
||||||
|
}
|
||||||
51
modules/options/options.go
Normal file
51
modules/options/options.go
Normal file
@@ -0,0 +1,51 @@
|
|||||||
|
// Copyright 2016 The Gitea Authors. All rights reserved.
|
||||||
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
|
package options
|
||||||
|
|
||||||
|
//go:generate go-bindata -tags "bindata" -ignore "TRANSLATORS" -pkg "options" -o "bindata.go" ../../options/...
|
||||||
|
//go:generate go fmt bindata.go
|
||||||
|
//go:generate sed -i.bak s/..\/..\/options\/// bindata.go
|
||||||
|
//go:generate rm -f bindata.go.bak
|
||||||
|
|
||||||
|
type directorySet map[string][]string
|
||||||
|
|
||||||
|
func (s directorySet) Add(key string, value []string) {
|
||||||
|
_, ok := s[key]
|
||||||
|
|
||||||
|
if !ok {
|
||||||
|
s[key] = make([]string, 0, len(value))
|
||||||
|
}
|
||||||
|
|
||||||
|
s[key] = append(s[key], value...)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s directorySet) Get(key string) []string {
|
||||||
|
_, ok := s[key]
|
||||||
|
|
||||||
|
if ok {
|
||||||
|
result := []string{}
|
||||||
|
seen := map[string]string{}
|
||||||
|
|
||||||
|
for _, val := range s[key] {
|
||||||
|
if _, ok := seen[val]; !ok {
|
||||||
|
result = append(result, val)
|
||||||
|
seen[val] = val
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return result
|
||||||
|
}
|
||||||
|
|
||||||
|
return []string{}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s directorySet) AddAndGet(key string, value []string) []string {
|
||||||
|
s.Add(key, value)
|
||||||
|
return s.Get(key)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s directorySet) Filled(key string) bool {
|
||||||
|
return len(s[key]) > 0
|
||||||
|
}
|
||||||
84
modules/options/static.go
Normal file
84
modules/options/static.go
Normal file
@@ -0,0 +1,84 @@
|
|||||||
|
// +build bindata
|
||||||
|
|
||||||
|
// Copyright 2016 The Gitea Authors. All rights reserved.
|
||||||
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
|
package options
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"io/ioutil"
|
||||||
|
"path"
|
||||||
|
|
||||||
|
"code.gitea.io/gitea/modules/setting"
|
||||||
|
"github.com/Unknwon/com"
|
||||||
|
)
|
||||||
|
|
||||||
|
var (
|
||||||
|
directories = make(directorySet)
|
||||||
|
)
|
||||||
|
|
||||||
|
// Dir returns all files from bindata or custom directory.
|
||||||
|
func Dir(name string) ([]string, error) {
|
||||||
|
if directories.Filled(name) {
|
||||||
|
return directories.Get(name), nil
|
||||||
|
}
|
||||||
|
|
||||||
|
var (
|
||||||
|
result []string
|
||||||
|
)
|
||||||
|
|
||||||
|
customDir := path.Join(setting.CustomPath, "options", name)
|
||||||
|
|
||||||
|
if com.IsDir(customDir) {
|
||||||
|
files, err := com.StatDir(customDir, true)
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
return []string{}, fmt.Errorf("Failed to read custom directory. %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
result = append(result, files...)
|
||||||
|
}
|
||||||
|
|
||||||
|
files, err := AssetDir(path.Join("..", "..", "options", name))
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
return []string{}, fmt.Errorf("Failed to read embedded directory. %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
result = append(result, files...)
|
||||||
|
|
||||||
|
return directories.AddAndGet(name, result), nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// Locale reads the content of a specific locale from bindata or custom path.
|
||||||
|
func Locale(name string) ([]byte, error) {
|
||||||
|
return fileFromDir(path.Join("locale", name))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Readme reads the content of a specific readme from bindata or custom path.
|
||||||
|
func Readme(name string) ([]byte, error) {
|
||||||
|
return fileFromDir(path.Join("readme", name))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Gitignore reads the content of a gitignore locale from bindata or custom path.
|
||||||
|
func Gitignore(name string) ([]byte, error) {
|
||||||
|
return fileFromDir(path.Join("gitignore", name))
|
||||||
|
}
|
||||||
|
|
||||||
|
// License reads the content of a specific license from bindata or custom path.
|
||||||
|
func License(name string) ([]byte, error) {
|
||||||
|
return fileFromDir(path.Join("license", name))
|
||||||
|
}
|
||||||
|
|
||||||
|
// fileFromDir is a helper to read files from bindata or custom path.
|
||||||
|
func fileFromDir(name string) ([]byte, error) {
|
||||||
|
customPath := path.Join(setting.CustomPath, "options", name)
|
||||||
|
|
||||||
|
if com.IsFile(customPath) {
|
||||||
|
return ioutil.ReadFile(customPath)
|
||||||
|
}
|
||||||
|
|
||||||
|
return Asset(name)
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user