Documentation ¶
Overview ¶
Package core is the core package for s5cmd.
Index ¶
- Constants
- Variables
- func CleanupError(err error) (s string)
- func GetCommandList() string
- func HumanizeBytes(b int64) string
- func IsRetryableError(err error) (string, bool)
- type AcceptableError
- type AcceptableErrorType
- type CancelableScanner
- type Job
- type JobArgument
- type WorkerParams
- type WorkerPool
- type WorkerPoolParams
Constants ¶
const CancelFuncKey = contextKey("cancelFunc")
CancelFuncKey is the key name of the cancel function in context
const ExitFuncKey = contextKey("exitFunc")
ExitFuncKey is the key name of the exit function in context
const ( // GlobCharacters is valid glob characters for local files GlobCharacters string = "?*[" )
Variables ¶
var ( // ErrFileExistsButOk is used when a destination file already exists and opt.IfNotExists is set. ErrFileExistsButOk = NewAcceptableError("File already exists") // ErrS3ExistsButOk is used when a destination object already exists and opt.IfNotExists is set. ErrS3ExistsButOk = NewAcceptableError("Object already exists") )
var ErrInterrupted = errors.New("Operation interrupted")
ErrInterrupted is the error used when the main context is canceled
var Verbose bool
Functions ¶
func CleanupError ¶
CleanupError converts multiline error messages generated by aws-sdk-go into a single line
func GetCommandList ¶
func GetCommandList() string
GetCommandList returns a text of accepted commands with their options and arguments
func HumanizeBytes ¶
HumanizeBytes takes a byte-size and returns a human-readable string
func IsRetryableError ¶
IsRetryableError returns if an error (probably awserr) is retryable, along with an error code
Types ¶
type AcceptableError ¶
AcceptableError interface defines an error which is OK-to-have, for things like "cp -n" etc. It should not be treated as an error (regarding the exit code etc)
func IsAcceptableError ¶
func IsAcceptableError(err error) AcceptableError
IsAcceptableError determines if the error is an AcceptableError, and if so, returns the error as such
type AcceptableErrorType ¶
type AcceptableErrorType struct {
// contains filtered or unexported fields
}
AcceptableErrorType embeds the stdlib error interface so that we can have more receivers on it
func NewAcceptableError ¶
func NewAcceptableError(s string) AcceptableErrorType
NewAcceptableError creates a new AcceptableError
func (AcceptableErrorType) Acceptable ¶
func (e AcceptableErrorType) Acceptable() bool
Acceptable is always true for errors of AcceptableError type
type CancelableScanner ¶
CancelableScanner is a scanner which also listens for the context cancellations and optionally pumps data between channels
func NewCancelableScanner ¶
func NewCancelableScanner(ctx context.Context, r io.Reader) *CancelableScanner
NewCancelableScanner creates a new CancelableScanner
func (*CancelableScanner) ReadOne ¶
func (s *CancelableScanner) ReadOne(from <-chan *Job, to chan<- *Job) (string, error)
ReadOne reads one line from the started CancelableScanner, as well as listening to ctx.Done messages and optionally/continuously pumping *Jobs from the from<- chan to the to<- chan
func (*CancelableScanner) Start ¶
func (s *CancelableScanner) Start() *CancelableScanner
Start stats the goroutine on the CancelableScanner and returns itself
type Job ¶
type Job struct {
// contains filtered or unexported fields
}
Job is our basic job type.
func ParseJob ¶
ParseJob parses a job description and returns a *Job type, possibly with other *Job types in successCommand/failCommand
func (Job) MakeSubJob ¶
func (j Job) MakeSubJob(command string, operation op.Operation, args []*JobArgument, opts opt.OptionList) *Job
MakeSubJob creates a sub-job linked to the original. sourceDesc is copied, numSuccess/numFails are linked. Returns a pointer to the new job.
func (*Job) PrintOK ¶
func (j *Job) PrintOK(err AcceptableError)
PrintOK notifies the user about the positive outcome of the job. Internal operations are not shown, sub-jobs use short syntax.
type JobArgument ¶
type JobArgument struct {
// contains filtered or unexported fields
}
JobArgument is an argument of the job. Can be a file/directory, an s3 url ("s3" is set in this case) or an arbitrary string.
func (*JobArgument) Append ¶
func (a *JobArgument) Append(s string, isS3path bool) *JobArgument
Append appends a string to a JobArgument and returns itself.
func (JobArgument) Clone ¶
func (a JobArgument) Clone() *JobArgument
Clone duplicates a JobArgument and returns a pointer to a new one
type WorkerParams ¶
type WorkerParams struct {
// contains filtered or unexported fields
}
WorkerParams is the params/state of a single worker.
type WorkerPool ¶
type WorkerPool struct {
// contains filtered or unexported fields
}
WorkerPool is the state of our worker pool.
func NewWorkerPool ¶
func NewWorkerPool(ctx context.Context, params *WorkerPoolParams, st *stats.Stats) *WorkerPool
NewWorkerPool creates a new worker pool and start the workers.
func (*WorkerPool) Run ¶
func (p *WorkerPool) Run(filename string)
Run runs the commands in filename in the worker pool, on EOF it will wait for all commands to finish, clean up and return.
func (*WorkerPool) RunCmd ¶
func (p *WorkerPool) RunCmd(commandLine string)
RunCmd will run a single command (and subsequent sub-commands) in the worker pool, wait for it to finish, clean up and return.
type WorkerPoolParams ¶
WorkerPoolParams is the common parameters of all worker pools.