 Documentation
      ¶
      Documentation
      ¶
    
    
  
    
  
    Overview ¶
package util implements various utility functions used within ipfs that do not currently have a better place to live.
Index ¶
- Variables
- func B58KeyEncode(k Key) string
- func ContextDo(ctx context.Context, f func() error) error
- func ContextWithErrorLog(parent context.Context) (context.Context, <-chan error)
- func ErrCast() error
- func ExpandPathnames(paths []string) ([]string, error)
- func FileExists(filename string) bool
- func FormatRFC3339(t time.Time) string
- func GetenvBool(name string) bool
- func Hash(data []byte) mh.Multihash
- func IsValidHash(s string) bool
- func LogError(ctx context.Context, err error)
- func Logger(name string) *logging.Logger
- func NewSeededRand(seed int64) io.Reader
- func NewTimeSeededRand() io.Reader
- func ParseRFC3339(s string) (time.Time, error)
- func Partition(subject string, sep string) (string, string, string)
- func RPartition(subject string, sep string) (string, string, string)
- func SetAllLoggers(lvl logging.Level)
- func SetDebugLogging()
- func SetLogLevel(name, level string) error
- func SetupLogging()
- func TildeExpansion(filename string) (string, error)
- func XOR(a, b []byte) []byte
- type Key
- type KeySet
- type KeySlice
- type MultiErr
Constants ¶
This section is empty.
Variables ¶
var B58KeyConverter = b58KeyConverter{}
    B58KeyConverter -- for KeyTransform datastores (static as only one obj needed)
var Debug bool
    Debug is a global flag for debugging.
var ErrNoSuchLogger = errors.New("Error: No such logger")
    ErrNoSuchLogger is returned when the util pkg is asked for a non existant logger
var ErrNotFound = ds.ErrNotFound
    ErrNotFound is returned when a search fails to find anything
var ErrNotImplemented = errors.New("Error: not implemented yet.")
    ErrNotImplemented signifies a function has not been implemented yet.
var ErrSearchIncomplete = errors.New("Error: Search Incomplete.")
    ErrSeErrSearchIncomplete implies that a search type operation didnt find the expected node, but did find 'a' node.
var ErrTimeout = errors.New("Error: Call timed out.")
    ErrTimeout implies that a timeout has been triggered
var LogFormats = map[string]string{
	"nocolor": "%{time:2006-01-02 15:04:05.000000} %{level} %{module} %{shortfile}: %{message}",
	"color": ansiGray + "%{time:15:04:05.000} %{color}%{level:5.5s} " + ansiBlue +
		"%{module:10.10s}: %{color:reset}%{message} " + ansiGray + "%{shortfile}%{color:reset}",
}
    LogFormats is a map of formats used for our logger, keyed by name.
var TimeFormatIpfs = time.RFC3339Nano
    Functions ¶
func B58KeyEncode ¶
B58KeyEncode returns Key in a b58 encoded string
func ContextWithErrorLog ¶
ContextWithErrorLog returns a copy of parent and an error channel that can be used to receive errors sent with the LogError method.
func ErrCast ¶
func ErrCast() error
ErrCast is returned when a cast fails AND the program should not panic.
func ExpandPathnames ¶
ExpandPathnames takes a set of paths and turns them into absolute paths
func FileExists ¶
func FormatRFC3339 ¶
func GetenvBool ¶
GetenvBool is the way to check an env var as a boolean
func IsValidHash ¶
IsValidHash checks whether a given hash is valid (b58 decodable, len > 0)
func LogError ¶
LogError logs the error to the owner of the context.
If this context was created with ContextWithErrorLog, then this method passes the error to context creator over an unbuffered channel.
If this context was created by other means, this method is a no-op.
func NewSeededRand ¶
func NewTimeSeededRand ¶
func SetAllLoggers ¶
SetAllLoggers changes the logging.Level of all loggers to lvl
func SetDebugLogging ¶
func SetDebugLogging()
SetDebugLogging calls SetAllLoggers with logging.DEBUG
func SetLogLevel ¶
SetLogLevel changes the log level of a specific subsystem name=="*" changes all subsystems
func SetupLogging ¶
func SetupLogging()
SetupLogging will initialize the logger backend and set the flags.
func TildeExpansion ¶
TildeExpansion expands a filename, which may begin with a tilde.
Types ¶
type Key ¶
type Key string
Key is a string representation of multihash for use with maps.
func B58KeyDecode ¶
B58KeyDecode returns Key from a b58 encoded string
func (*Key) MarshalJSON ¶
MarshalJSON returns a JSON-encoded Key (string)
func (Key) ToMultihash ¶
func (*Key) UnmarshalJSON ¶
UnmarshalJSON returns a JSON-encoded Key (string)
       Directories
      ¶
      Directories
      ¶
    
    | Path | Synopsis | 
|---|---|
| package debugerror provides ways to augment errors with additional information to allow for easier debugging. | package debugerror provides ways to augment errors with additional information to allow for easier debugging. | 
| eventlog
       | |
| 
          
            loggables
            
            
          
           Package loggables includes a bunch of transaltor functions for commonplace/stdlib objects. | Package loggables includes a bunch of transaltor functions for commonplace/stdlib objects. | 
| 
          
            ci
            
            
          
           Package ci implements some helper functions to use during tests. | Package ci implements some helper functions to use during tests. | 
| 
          
            ci/jenkins
            
            
          
           Package jenkins implements some helper functions to use during tests. | Package jenkins implements some helper functions to use during tests. | 
| 
          
            ci/travis
            
            
          
           Package travis implements some helper functions to use during tests. | Package travis implements some helper functions to use during tests. |