1
0
mirror of https://github.com/minio/mc.git synced 2025-11-12 01:02:26 +03:00
Files
mc/cmd/status.go
Harshavardhana 2ea2ec90d2 Rename mc --> cmd
2016-08-17 18:26:18 -07:00

202 lines
4.5 KiB
Go

/*
* Minio Client, (C) 2016 Minio, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package cmd
import (
"github.com/minio/mc/pkg/console"
"github.com/minio/minio/pkg/probe"
)
// Status implements a interface that can be used in quit mode or with progressbar.
type Status interface {
Println(data ...interface{})
Add(int64) Status
Start()
Finish()
PrintMsg(msg message)
Update()
Total() int64
SetTotal(int64) Status
SetCaption(string)
Read(p []byte) (n int, err error)
errorIf(err *probe.Error, msg string)
fatalIf(err *probe.Error, msg string)
}
// NewQuietStatus returns a quiet status object
func NewQuietStatus() Status {
return &QuietStatus{
newAccounter(0),
}
}
// QuietStatus will only show the progress and summary
type QuietStatus struct {
*accounter
}
// Read implements the io.Reader interface
func (qs *QuietStatus) Read(p []byte) (n int, err error) {
return qs.accounter.Read(p)
}
// SetTotal sets the total of the progressbar, ignored for quietstatus
func (qs *QuietStatus) SetTotal(v int64) Status {
qs.accounter.Total = v
return qs
}
// SetCaption sets the caption of the progressbar, ignored for quietstatus
func (qs *QuietStatus) SetCaption(s string) {
}
// Total returns the total number of bytes
func (qs *QuietStatus) Total() int64 {
return qs.accounter.Total
}
// Add bytes to current number of bytes
func (qs *QuietStatus) Add(v int64) Status {
qs.accounter.Add(v)
return qs
}
// Println prints line, ignored for quietstatus
func (qs *QuietStatus) Println(data ...interface{}) {
}
// PrintMsg prints message
func (qs *QuietStatus) PrintMsg(msg message) {
if !globalJSON {
console.Println(msg.String())
} else {
console.Println(msg.JSON())
}
}
// Start is ignored for quietstatus
func (qs *QuietStatus) Start() {
}
// Finish displays the accounting summary
func (qs *QuietStatus) Finish() {
accntStat := qs.accounter.Stat()
cpStatMessage := mirrorStatMessage{
Total: accntStat.Total,
Transferred: accntStat.Transferred,
Speed: accntStat.Speed,
}
console.Println(console.Colorize("Mirror", cpStatMessage.String()))
}
// Update is ignored for quietstatus
func (qs *QuietStatus) Update() {
}
func (qs *QuietStatus) errorIf(err *probe.Error, msg string) {
errorIf(err, msg)
}
func (qs *QuietStatus) fatalIf(err *probe.Error, msg string) {
fatalIf(err, msg)
}
// NewProgressStatus returns a progress status object
func NewProgressStatus() Status {
return &ProgressStatus{
newProgressBar(0),
}
}
// ProgressStatus shows a progressbar
type ProgressStatus struct {
*progressBar
}
// Read implements the io.Reader interface
func (ps *ProgressStatus) Read(p []byte) (n int, err error) {
return ps.progressBar.Read(p)
}
// SetCaption sets the caption of the progressbar
func (ps *ProgressStatus) SetCaption(s string) {
ps.progressBar.SetCaption(s)
}
// Total returns the total number of bytes
func (ps *ProgressStatus) Total() int64 {
return ps.progressBar.Total
}
// SetTotal sets the total of the progressbar
func (ps *ProgressStatus) SetTotal(v int64) Status {
ps.progressBar.Total = v
return ps
}
// Add bytes to current number of bytes
func (ps *ProgressStatus) Add(v int64) Status {
ps.progressBar.Add64(v)
return ps
}
// Println prints line, ignored for quietstatus
func (ps *ProgressStatus) Println(data ...interface{}) {
console.Eraseline()
console.Println(data...)
}
// PrintMsg prints message
func (ps *ProgressStatus) PrintMsg(msg message) {
}
// Start is ignored for quietstatus
func (ps *ProgressStatus) Start() {
ps.progressBar.Start()
}
// Finish displays the accounting summary
func (ps *ProgressStatus) Finish() {
ps.progressBar.Finish()
}
// Update is ignored for quietstatus
func (ps *ProgressStatus) Update() {
ps.progressBar.Update()
}
func (ps *ProgressStatus) errorIf(err *probe.Error, msg string) {
// remove progressbar
console.Eraseline()
errorIf(err, msg)
ps.progressBar.Update()
}
func (ps *ProgressStatus) fatalIf(err *probe.Error, msg string) {
// remove progressbar
console.Eraseline()
fatalIf(err, msg)
ps.progressBar.Update()
}