Documentation ¶
Overview ¶
Package hugofs provides the file systems used by Hugo.
Package hugofs provides the file systems used by Hugo.
Index ¶
- Variables
- func DecorateBasePathFs(base *afero.BasePathFs) afero.Fs
- func Glob(fs afero.Fs, pattern string, handle func(fi FileMetaInfo) (bool, error)) error
- func IsOsFs(fs afero.Fs) bool
- func MakeReadableAndRemoveAllModulePkgDir(fs afero.Fs, dir string) (int, error)
- func NewBaseFileDecorator(fs afero.Fs, callbacks ...func(fi FileMetaInfo)) afero.Fs
- func NewCreateCountingFs(fs afero.Fs) afero.Fs
- func NewFilterFs(fs afero.Fs) (afero.Fs, error)
- func NewHasBytesReceiver(delegate afero.Fs, shouldCheck func(name string) bool, ...) afero.Fs
- func NewHashingFs(delegate afero.Fs, hashReceiver FileHashReceiver) afero.Fs
- func NewLanguageFs(langs map[string]int, fs afero.Fs) (afero.Fs, error)
- func NewNoSymlinkFs(fs afero.Fs, logger loggers.Logger, allowFiles bool) afero.Fs
- func NewSliceFs(dirs ...FileMetaInfo) (afero.Fs, error)
- func NewStacktracerFs(fs afero.Fs, pattern string) afero.Fs
- func WalkFilesystems(fs afero.Fs, fn WalkFn) bool
- type DuplicatesReporter
- type FileHashReceiver
- type FileMeta
- type FileMetaInfo
- type FilesystemUnwrapper
- type FilesystemsUnwrapper
- type FilterFs
- func (fs *FilterFs) Chmod(n string, m os.FileMode) error
- func (fs *FilterFs) Chown(n string, uid, gid int) error
- func (fs *FilterFs) Chtimes(n string, a, m time.Time) error
- func (fs *FilterFs) Create(n string) (afero.File, error)
- func (fs *FilterFs) LstatIfPossible(name string) (os.FileInfo, bool, error)
- func (fs *FilterFs) Mkdir(n string, p os.FileMode) error
- func (fs *FilterFs) MkdirAll(n string, p os.FileMode) error
- func (fs *FilterFs) Name() string
- func (fs *FilterFs) Open(name string) (afero.File, error)
- func (fs *FilterFs) OpenFile(name string, flag int, perm os.FileMode) (afero.File, error)
- func (fs *FilterFs) ReadDir(name string) ([]os.FileInfo, error)
- func (fs *FilterFs) Remove(n string) error
- func (fs *FilterFs) RemoveAll(p string) error
- func (fs *FilterFs) Rename(o, n string) error
- func (fs *FilterFs) Stat(name string) (os.FileInfo, error)
- func (fs *FilterFs) UnwrapFilesystem() afero.Fs
- type Fs
- type Reseter
- type RootMapping
- type RootMappingFs
- func (fs *RootMappingFs) Dirs(base string) ([]FileMetaInfo, error)
- func (fs RootMappingFs) Filter(f func(m RootMapping) bool) *RootMappingFs
- func (fs *RootMappingFs) LstatIfPossible(name string) (os.FileInfo, bool, error)
- func (fs *RootMappingFs) Open(name string) (afero.File, error)
- func (fs *RootMappingFs) Stat(name string) (os.FileInfo, error)
- func (fs *RootMappingFs) UnwrapFilesystem() afero.Fs
- type SliceFs
- func (fs *SliceFs) Chmod(n string, m os.FileMode) error
- func (fs *SliceFs) Chown(n string, uid, gid int) error
- func (fs *SliceFs) Chtimes(n string, a, m time.Time) error
- func (fs *SliceFs) Create(n string) (afero.File, error)
- func (fs *SliceFs) LstatIfPossible(name string) (os.FileInfo, bool, error)
- func (fs *SliceFs) Mkdir(n string, p os.FileMode) error
- func (fs *SliceFs) MkdirAll(n string, p os.FileMode) error
- func (fs *SliceFs) Name() string
- func (fs *SliceFs) Open(name string) (afero.File, error)
- func (fs *SliceFs) OpenFile(name string, flag int, perm os.FileMode) (afero.File, error)
- func (fs *SliceFs) ReadDir(name string) ([]os.FileInfo, error)
- func (fs *SliceFs) Remove(n string) error
- func (fs *SliceFs) RemoveAll(p string) error
- func (fs *SliceFs) Rename(o, n string) error
- func (fs *SliceFs) Stat(name string) (os.FileInfo, error)
- func (fs *SliceFs) UnwrapFilesystems() []afero.Fs
- type WalkFn
- type WalkFunc
- type WalkHook
- type Walkway
- type WalkwayConfig
Constants ¶
This section is empty.
Variables ¶
var ErrPermissionSymlink = errors.New("symlinks not allowed in this filesystem")
var LanguageDirsMerger = func(lofi, bofi []os.FileInfo) []os.FileInfo { for _, fi1 := range bofi { fim1 := fi1.(FileMetaInfo) var found bool for _, fi2 := range lofi { fim2 := fi2.(FileMetaInfo) if fi1.Name() == fi2.Name() && fim1.Meta().Lang == fim2.Meta().Lang { found = true break } } if !found { lofi = append(lofi, fi1) } } return lofi }
LanguageDirsMerger implements the overlayfs.DirsMerger func, which is used to merge two directories.
var ( // NoOpFs provides a no-op filesystem that implements the afero.Fs // interface. NoOpFs = &noOpFs{} )
var Os = &afero.OsFs{}
Os points to the (real) Os filesystem.
Functions ¶
func DecorateBasePathFs ¶ added in v1.0.0
func DecorateBasePathFs(base *afero.BasePathFs) afero.Fs
DecorateBasePathFs adds Path info to files and directories in the provided BasePathFs, using the base as base.
func Glob ¶ added in v1.0.0
Glob walks the fs and passes all matches to the handle func. The handle func can return true to signal a stop.
func IsOsFs ¶ added in v1.0.0
HasOsFs returns whether fs is an OsFs or if it fs wraps an OsFs. TODO(bep) make this nore robust.
func MakeReadableAndRemoveAllModulePkgDir ¶ added in v1.0.0
MakeReadableAndRemoveAllModulePkgDir makes any subdir in dir readable and then removes the root. TODO(bep) move this to a more suitable place.
func NewBaseFileDecorator ¶ added in v1.0.0
func NewBaseFileDecorator(fs afero.Fs, callbacks ...func(fi FileMetaInfo)) afero.Fs
NewBaseFileDecorator decorates the given Fs to provide the real filename and an Opener func.
func NewHasBytesReceiver ¶ added in v1.0.0
func NewHashingFs ¶ added in v0.45.1
func NewHashingFs(delegate afero.Fs, hashReceiver FileHashReceiver) afero.Fs
NewHashingFs creates a new filesystem that will receive MD5 checksums of any written file content on Close. Note that this is probably not a good idea for "full build" situations, but when doing fast render mode, the amount of files published is low, and it would be really nice to know exactly which of these files where actually changed. Note that this will only work for file operations that use the io.Writer to write content to file, but that is fine for the "publish content" use case.
func NewLanguageFs ¶ added in v0.38.1
func NewNoSymlinkFs ¶ added in v1.0.0
NewNoSymlinkFs creates a new filesystem that prevents symlinks.
func NewSliceFs ¶ added in v1.0.0
func NewSliceFs(dirs ...FileMetaInfo) (afero.Fs, error)
func NewStacktracerFs ¶ added in v1.0.0
NewStacktracerFs wraps the given fs printing stack traces for file creates matching the given regexp pattern.
Types ¶
type DuplicatesReporter ¶ added in v1.0.0
type DuplicatesReporter interface {
ReportDuplicates() string
}
DuplicatesReporter reports about duplicate filenames.
type FileHashReceiver ¶ added in v0.45.1
type FileHashReceiver interface {
OnFileClose(name, md5sum string)
}
FileHashReceiver will receive the filename an the content's MD5 sum on file close.
type FileMeta ¶ added in v1.0.0
type FileMeta struct { Name string Filename string Path string PathWalk string OriginalFilename string BaseDir string SourceRoot string MountRoot string Module string Weight int IsOrdered bool IsSymlink bool IsRootFile bool IsProject bool Watch bool Classifier files.ContentClass SkipDir bool Lang string TranslationBaseName string TranslationBaseNameWithExt string Translations []string Fs afero.Fs OpenFunc func() (afero.File, error) JoinStatFunc func(name string) (FileMetaInfo, error) // Include only files or directories that match. InclusionFilter *glob.FilenameFilter }
func NewFileMeta ¶ added in v1.0.0
func NewFileMeta() *FileMeta
type FileMetaInfo ¶ added in v1.0.0
func NewFileMetaInfo ¶ added in v1.0.0
func NewFileMetaInfo(fi os.FileInfo, m *FileMeta) FileMetaInfo
type FilesystemUnwrapper ¶ added in v1.0.0
FilesystemsProvider returns the underlying filesystem.
type FilesystemsUnwrapper ¶ added in v1.0.0
FilesystemsUnwrapper returns the underlying filesystems.
type FilterFs ¶ added in v1.0.0
type FilterFs struct {
// contains filtered or unexported fields
}
FilterFs is an ordered composite filesystem.
func (*FilterFs) LstatIfPossible ¶ added in v1.0.0
func (*FilterFs) UnwrapFilesystem ¶ added in v1.0.0
type Fs ¶ added in v0.20.1
type Fs struct { // Source is Hugo's source file system. // Note that this will always be a "plain" Afero filesystem: // * afero.OsFs when running in production // * afero.MemMapFs for many of the tests. Source afero.Fs // PublishDir is where Hugo publishes its rendered content. // It's mounted inside publishDir (default /public). PublishDir afero.Fs // PublishDirStatic is the file system used for static files. PublishDirStatic afero.Fs // PublishDirServer is the file system used for serving the public directory with Hugo's development server. // This will typically be the same as PublishDir, but not if --renderStaticToDisk is set. PublishDirServer afero.Fs // Os is an OS file system. // NOTE: Field is currently unused. Os afero.Fs // WorkingDirReadOnly is a read-only file system // restricted to the project working dir. WorkingDirReadOnly afero.Fs // WorkingDirWritable is a writable file system // restricted to the project working dir. WorkingDirWritable afero.Fs }
Fs holds the core filesystems used by Hugo.
func NewDefault ¶ added in v0.20.1
NewDefault creates a new Fs with the OS file system as source and destination file systems.
func NewFrom ¶ added in v0.20.1
NewFrom creates a new Fs based on the provided Afero Fs as source and destination file systems. Useful for testing.
func NewFromSourceAndDestination ¶ added in v1.0.0
NewFrom creates a new Fs based on the provided Afero Fss as the source and destination file systems.
type Reseter ¶ added in v1.0.0
type Reseter interface {
Reset()
}
Reseter is implemented by some of the stateful filesystems.
type RootMapping ¶ added in v1.0.0
type RootMapping struct { From string // The virtual mount. To string // The source directory or file. ToBasedir string // The base of To. May be empty if an absolute path was provided. Module string // The module path/ID. IsProject bool // Whether this is a mount in the main project. Meta *FileMeta // File metadata (lang etc.) // contains filtered or unexported fields }
RootMapping describes a virtual file or directory mount.
type RootMappingFs ¶ added in v0.42.1
A RootMappingFs maps several roots into one. Note that the root of this filesystem is directories only, and they will be returned in Readdir and Readdirnames in the order given.
func NewRootMappingFs ¶ added in v0.42.1
func NewRootMappingFs(fs afero.Fs, rms ...RootMapping) (*RootMappingFs, error)
NewRootMappingFs creates a new RootMappingFs on top of the provided with root mappings with some optional metadata about the root. Note that From represents a virtual root that maps to the actual filename in To.
func (*RootMappingFs) Dirs ¶ added in v1.0.0
func (fs *RootMappingFs) Dirs(base string) ([]FileMetaInfo, error)
func (RootMappingFs) Filter ¶ added in v1.0.0
func (fs RootMappingFs) Filter(f func(m RootMapping) bool) *RootMappingFs
Filter creates a copy of this filesystem with only mappings matching a filter.
func (*RootMappingFs) LstatIfPossible ¶ added in v0.42.1
LstatIfPossible returns the os.FileInfo structure describing a given file.
func (*RootMappingFs) Open ¶ added in v0.42.1
func (fs *RootMappingFs) Open(name string) (afero.File, error)
Open opens the named file for reading.
func (*RootMappingFs) Stat ¶ added in v0.42.1
func (fs *RootMappingFs) Stat(name string) (os.FileInfo, error)
Stat returns the os.FileInfo structure describing a given file. If there is an error, it will be of type *os.PathError.
func (*RootMappingFs) UnwrapFilesystem ¶ added in v1.0.0
func (fs *RootMappingFs) UnwrapFilesystem() afero.Fs
type SliceFs ¶ added in v1.0.0
type SliceFs struct {
// contains filtered or unexported fields
}
SliceFs is an ordered composite filesystem.
func (*SliceFs) LstatIfPossible ¶ added in v1.0.0
func (*SliceFs) UnwrapFilesystems ¶ added in v1.0.0
type WalkHook ¶ added in v1.0.0
type WalkHook func(dir FileMetaInfo, path string, readdir []FileMetaInfo) ([]FileMetaInfo, error)
type Walkway ¶ added in v1.0.0
type Walkway struct {
// contains filtered or unexported fields
}
func NewWalkway ¶ added in v1.0.0
func NewWalkway(cfg WalkwayConfig) *Walkway