mirror of
https://github.com/shirou/gopsutil.git
synced 2025-05-10 19:29:14 +08:00
Merge pull request #1182 from kestrelcjx/kestrel/process
fix(process): fix the bug that the program is hung when getting the f…
This commit is contained in:
commit
de385f50a8
@ -12,6 +12,7 @@ import (
|
||||
"reflect"
|
||||
"strings"
|
||||
"syscall"
|
||||
"time"
|
||||
"unicode/utf16"
|
||||
"unsafe"
|
||||
|
||||
@ -720,13 +721,24 @@ func (p *Process) OpenFilesWithContext(ctx context.Context) ([]OpenFilesStat, er
|
||||
continue
|
||||
}
|
||||
|
||||
var fileName string
|
||||
ch := make(chan struct{})
|
||||
|
||||
go func() {
|
||||
var buf [syscall.MAX_LONG_PATH]uint16
|
||||
n, err := windows.GetFinalPathNameByHandle(windows.Handle(file), &buf[0], syscall.MAX_LONG_PATH, 0)
|
||||
if err != nil {
|
||||
continue
|
||||
return
|
||||
}
|
||||
|
||||
fileName := string(utf16.Decode(buf[:n]))
|
||||
fileName = string(utf16.Decode(buf[:n]))
|
||||
ch <- struct{}{}
|
||||
}()
|
||||
|
||||
select {
|
||||
case <-time.NewTimer(100 * time.Millisecond).C:
|
||||
continue
|
||||
case <-ch:
|
||||
fileInfo, _ := os.Stat(fileName)
|
||||
if fileInfo.IsDir() {
|
||||
continue
|
||||
@ -739,6 +751,9 @@ func (p *Process) OpenFilesWithContext(ctx context.Context) ([]OpenFilesStat, er
|
||||
})
|
||||
fileExists[fileName] = true
|
||||
}
|
||||
case <-ctx.Done():
|
||||
return files, ctx.Err()
|
||||
}
|
||||
}
|
||||
|
||||
return files, nil
|
||||
|
@ -12,6 +12,7 @@ import (
|
||||
"reflect"
|
||||
"strings"
|
||||
"syscall"
|
||||
"time"
|
||||
"unicode/utf16"
|
||||
"unsafe"
|
||||
|
||||
@ -707,13 +708,24 @@ func (p *Process) OpenFilesWithContext(ctx context.Context) ([]OpenFilesStat, er
|
||||
continue
|
||||
}
|
||||
|
||||
var fileName string
|
||||
ch := make(chan struct{})
|
||||
|
||||
go func() {
|
||||
var buf [syscall.MAX_LONG_PATH]uint16
|
||||
n, err := windows.GetFinalPathNameByHandle(windows.Handle(file), &buf[0], syscall.MAX_LONG_PATH, 0)
|
||||
if err != nil {
|
||||
continue
|
||||
return
|
||||
}
|
||||
|
||||
fileName := string(utf16.Decode(buf[:n]))
|
||||
fileName = string(utf16.Decode(buf[:n]))
|
||||
ch <- struct{}{}
|
||||
}()
|
||||
|
||||
select {
|
||||
case <-time.NewTimer(100 * time.Millisecond).C:
|
||||
continue
|
||||
case <-ch:
|
||||
fileInfo, _ := os.Stat(fileName)
|
||||
if fileInfo.IsDir() {
|
||||
continue
|
||||
@ -726,6 +738,9 @@ func (p *Process) OpenFilesWithContext(ctx context.Context) ([]OpenFilesStat, er
|
||||
})
|
||||
fileExists[fileName] = true
|
||||
}
|
||||
case <-ctx.Done():
|
||||
return files, ctx.Err()
|
||||
}
|
||||
}
|
||||
|
||||
return files, nil
|
||||
|
Loading…
x
Reference in New Issue
Block a user