2017-10-27 00:10:54 -06:00
|
|
|
// Copyright 2017 The Gitea Authors. All rights reserved.
|
|
|
|
// Use of this source code is governed by a MIT-style
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
|
|
|
package util
|
|
|
|
|
2019-11-10 14:33:47 -07:00
|
|
|
import (
|
|
|
|
"os"
|
|
|
|
"path/filepath"
|
|
|
|
)
|
2017-10-27 00:10:54 -06:00
|
|
|
|
|
|
|
// EnsureAbsolutePath ensure that a path is absolute, making it
|
|
|
|
// relative to absoluteBase if necessary
|
|
|
|
func EnsureAbsolutePath(path string, absoluteBase string) string {
|
|
|
|
if filepath.IsAbs(path) {
|
|
|
|
return path
|
|
|
|
}
|
|
|
|
return filepath.Join(absoluteBase, path)
|
|
|
|
}
|
2019-11-10 14:33:47 -07:00
|
|
|
|
|
|
|
const notRegularFileMode os.FileMode = os.ModeDir | os.ModeSymlink | os.ModeNamedPipe | os.ModeSocket | os.ModeDevice | os.ModeCharDevice | os.ModeIrregular
|
|
|
|
|
|
|
|
// GetDirectorySize returns the dumb disk consumption for a given path
|
|
|
|
func GetDirectorySize(path string) (int64, error) {
|
|
|
|
var size int64
|
|
|
|
err := filepath.Walk(path, func(_ string, info os.FileInfo, err error) error {
|
|
|
|
if info != nil && (info.Mode()¬RegularFileMode) == 0 {
|
|
|
|
size += info.Size()
|
|
|
|
}
|
|
|
|
return err
|
|
|
|
})
|
|
|
|
return size, err
|
|
|
|
}
|