| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374 |
- // Copyright 2019 Yunion
- //
- // 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 esxi
- import (
- "github.com/vmware/govmomi/vim25/progress"
- "yunion.io/x/log"
- )
- type logger struct {
- name string
- chid chan progress.Report
- over chan struct{}
- }
- func (l *logger) Sink() chan<- progress.Report {
- return l.chid
- }
- func (l *logger) End() {
- close(l.over)
- }
- func newLeaseLogger(name string, cap int) *logger {
- return &logger{
- name: name,
- chid: make(chan progress.Report, cap),
- over: make(chan struct{}),
- }
- }
- func (l *logger) Log() {
- go func() {
- var pre float32 = 0
- log.Debugf("logger.Log...")
- Loop:
- for {
- select {
- case r, ok := <-l.chid:
- if !ok {
- break Loop
- }
- if r.Error() != nil {
- log.Errorf("%s report, error: %s", l.name, r.Error())
- break Loop
- }
- if r.Percentage() >= pre {
- log.Debugf("%s report: speed: %s, percentage: %f%%", l.name, r.Detail(), pre)
- pre += 10
- }
- if r.Percentage() >= 110 {
- break Loop
- }
- case <-l.over:
- break Loop
- }
- }
- }()
- }
|