mirror of
https://github.com/minio/minio.git
synced 2025-04-07 05:10:30 -04:00
refactor: reuse open file in storage interface (#16970)
This commit is contained in:
parent
25f7a8e406
commit
056ca0c68e
@ -1671,35 +1671,10 @@ func (s *xlStorage) openFileDirect(path string, mode int) (f *os.File, err error
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (s *xlStorage) openFileSync(filePath string, mode int) (f *os.File, err error) {
|
func (s *xlStorage) openFileSync(filePath string, mode int) (f *os.File, err error) {
|
||||||
// Create top level directories if they don't exist.
|
return s.openFile(filePath, mode|writeMode)
|
||||||
// with mode 0777 mkdir honors system umask.
|
|
||||||
if err = mkdirAll(pathutil.Dir(filePath), 0o777); err != nil {
|
|
||||||
return nil, osErrToFileErr(err)
|
|
||||||
}
|
|
||||||
|
|
||||||
w, err := OpenFile(filePath, mode|writeMode, 0o666)
|
|
||||||
if err != nil {
|
|
||||||
// File path cannot be verified since one of the parents is a file.
|
|
||||||
switch {
|
|
||||||
case isSysErrIsDir(err):
|
|
||||||
return nil, errIsNotRegular
|
|
||||||
case osIsPermission(err):
|
|
||||||
return nil, errFileAccessDenied
|
|
||||||
case isSysErrNotDir(err):
|
|
||||||
return nil, errFileAccessDenied
|
|
||||||
case isSysErrIO(err):
|
|
||||||
return nil, errFaultyDisk
|
|
||||||
case isSysErrTooManyFiles(err):
|
|
||||||
return nil, errTooManyOpenFiles
|
|
||||||
default:
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return w, nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *xlStorage) openFileNoSync(filePath string, mode int) (f *os.File, err error) {
|
func (s *xlStorage) openFile(filePath string, mode int) (f *os.File, err error) {
|
||||||
// Create top level directories if they don't exist.
|
// Create top level directories if they don't exist.
|
||||||
// with mode 0777 mkdir honors system umask.
|
// with mode 0777 mkdir honors system umask.
|
||||||
if err = mkdirAll(pathutil.Dir(filePath), 0o777); err != nil {
|
if err = mkdirAll(pathutil.Dir(filePath), 0o777); err != nil {
|
||||||
@ -1950,7 +1925,7 @@ func (s *xlStorage) writeAll(ctx context.Context, volume string, path string, b
|
|||||||
}
|
}
|
||||||
w, err = s.openFileSync(filePath, flags)
|
w, err = s.openFileSync(filePath, flags)
|
||||||
} else {
|
} else {
|
||||||
w, err = s.openFileNoSync(filePath, flags)
|
w, err = s.openFile(filePath, flags)
|
||||||
}
|
}
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
|
Loading…
x
Reference in New Issue
Block a user