2016-12-22 21:12:23 +03:00
// 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.
2021-08-24 19:47:09 +03:00
//go:build bindata
// +build bindata
2016-12-22 21:12:23 +03:00
package options
import (
"fmt"
2021-09-22 08:38:34 +03:00
"io"
"os"
2016-12-22 21:12:23 +03:00
"path"
2020-11-28 05:42:08 +03:00
"code.gitea.io/gitea/modules/log"
2016-12-22 21:12:23 +03:00
"code.gitea.io/gitea/modules/setting"
2020-11-28 05:42:08 +03:00
"code.gitea.io/gitea/modules/util"
2016-12-22 21:12:23 +03:00
)
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 )
2020-11-28 05:42:08 +03:00
isDir , err := util . IsDir ( customDir )
if err != nil {
return [ ] string { } , fmt . Errorf ( "Failed to check if custom directory %s is a directory. %v" , err )
}
if isDir {
2020-12-22 02:40:57 +03:00
files , err := util . StatDir ( customDir , true )
2016-12-22 21:12:23 +03:00
if err != nil {
return [ ] string { } , fmt . Errorf ( "Failed to read custom directory. %v" , err )
}
result = append ( result , files ... )
}
2019-06-03 00:43:47 +03:00
files , err := AssetDir ( name )
2016-12-22 21:12:23 +03:00
if err != nil {
return [ ] string { } , fmt . Errorf ( "Failed to read embedded directory. %v" , err )
}
result = append ( result , files ... )
return directories . AddAndGet ( name , result ) , nil
}
2019-06-03 00:43:47 +03:00
func AssetDir ( dirName string ) ( [ ] string , error ) {
d , err := Assets . Open ( dirName )
if err != nil {
return nil , err
}
defer d . Close ( )
files , err := d . Readdir ( - 1 )
if err != nil {
return nil , err
}
var results = make ( [ ] string , 0 , len ( files ) )
for _ , file := range files {
results = append ( results , file . Name ( ) )
}
return results , nil
}
2016-12-22 21:12:23 +03:00
// 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 ) )
}
2017-03-15 03:52:01 +03:00
// Labels reads the content of a specific labels from static or custom path.
2016-12-23 10:18:05 +03:00
func Labels ( name string ) ( [ ] byte , error ) {
return fileFromDir ( path . Join ( "label" , name ) )
}
2016-12-22 21:12:23 +03:00
// 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 )
2020-11-28 05:42:08 +03:00
isFile , err := util . IsFile ( customPath )
if err != nil {
log . Error ( "Unable to check if %s is a file. Error: %v" , customPath , err )
}
if isFile {
2021-09-22 08:38:34 +03:00
return os . ReadFile ( customPath )
2016-12-22 21:12:23 +03:00
}
2019-06-03 00:43:47 +03:00
f , err := Assets . Open ( name )
if err != nil {
return nil , err
}
defer f . Close ( )
2021-09-22 08:38:34 +03:00
return io . ReadAll ( f )
2016-12-22 21:12:23 +03:00
}
2020-01-30 05:00:27 +03:00
2020-02-02 05:17:44 +03:00
func Asset ( name string ) ( [ ] byte , error ) {
f , err := Assets . Open ( "/" + name )
if err != nil {
return nil , err
}
defer f . Close ( )
2021-09-22 08:38:34 +03:00
return io . ReadAll ( f )
2020-02-02 05:17:44 +03:00
}
func AssetNames ( ) [ ] string {
realFS := Assets . ( vfsgen۰ FS )
var results = make ( [ ] string , 0 , len ( realFS ) )
for k := range realFS {
results = append ( results , k [ 1 : ] )
}
return results
}
func AssetIsDir ( name string ) ( bool , error ) {
if f , err := Assets . Open ( "/" + name ) ; err != nil {
return false , err
} else {
defer f . Close ( )
if fi , err := f . Stat ( ) ; err != nil {
return false , err
} else {
return fi . IsDir ( ) , nil
}
}
}
2020-01-30 05:00:27 +03:00
// IsDynamic will return false when using embedded data (-tags bindata)
func IsDynamic ( ) bool {
return false
}