1234567891011121314151617181920212223242526272829303132333435363738394041 |
- // Copyright (C) 2016 The Syncthing Authors.
- //
- // This Source Code Form is subject to the terms of the Mozilla Public
- // License, v. 2.0. If a copy of the MPL was not distributed with this file,
- // You can obtain one at https://mozilla.org/MPL/2.0/.
- package fs
- import "sync"
- type FilesystemType string
- // Option modifies a filesystem at creation. An option might be specific
- // to a filesystem-type.
- //
- // String is used to detect options with the same effect, i.e. must be different
- // for options with different effects. Meaning if an option has parameters, a
- // representation of those must be part of the returned string.
- type Option interface {
- String() string
- apply(Filesystem) Filesystem
- }
- // Factory function type for constructing a custom file system. It takes the URI
- // and options as its parameters.
- type FilesystemFactory func(string, ...Option) (Filesystem, error)
- // For each registered file system type, a function to construct a file system.
- var (
- filesystemFactories map[FilesystemType]FilesystemFactory = make(map[FilesystemType]FilesystemFactory)
- filesystemFactoriesMutex sync.Mutex = sync.Mutex{}
- )
- // Register a function to be called when a filesystem is to be constructed with
- // the specified fsType. The function will receive the URI for the file system as well
- // as all options.
- func RegisterFilesystemType(fsType FilesystemType, fn FilesystemFactory) {
- filesystemFactoriesMutex.Lock()
- defer filesystemFactoriesMutex.Unlock()
- filesystemFactories[fsType] = fn
- }
|