-
Notifications
You must be signed in to change notification settings - Fork 45
/
Copy pathdogo_windows.go
69 lines (61 loc) · 2.22 KB
/
dogo_windows.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
// Copyright 2014 The dogo Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package main
import (
"fmt"
"log"
"syscall"
"time"
)
func (d *Dogo) Monitor() {
var err error
var dwChangeHandles [4]syscall.Handle
// | FILE_NOTIFY_CHANGE_ATTRIBUTES | FILE_NOTIFY_CHANGE_SIZE | FILE_NOTIFY_CHANGE_SECURITY
var flags uint32 = FILE_NOTIFY_CHANGE_FILE_NAME | FILE_NOTIFY_CHANGE_DIR_NAME | FILE_NOTIFY_CHANGE_LAST_WRITE
var handlesCount uint32 = uint32(len(d.SourceDir))
if handlesCount > 4 {
log.Fatalf("[dogo] Error: The number of SourceDir folders can not be more than 4\n")
}
for k, dir := range d.SourceDir {
// Watch the directory(and subtree) for file creation and deletion and modify.
dwChangeHandles[k], err = FindFirstChangeNotification(dir, true, flags)
if err != nil {
log.Fatalf("[dogo] Error: %s\n", err.Error())
}
}
var decreasing uint8
// Change notification is set. Now wait on both notification
// handles and refresh accordingly.
for {
// Wait for notification.
dwWaitStatus, err := WaitForMultipleObjects(handlesCount, &dwChangeHandles, false, INFINITE)
if err != nil {
log.Fatalf("[dogo] Error: %s\n", err.Error())
}
if dwWaitStatus >= 0 && dwWaitStatus < handlesCount {
if decreasing > 0 {
decreasing--
fmt.Printf("[dogo] Decreasing %d: %v\n", decreasing, d.SourceDir[dwWaitStatus])
} else {
d.isModified = true
fmt.Printf("[dogo] Changed files: %v\n", d.SourceDir[dwWaitStatus])
d.BuildAndRun()
decreasing = d.Decreasing
time.Sleep(time.Duration(1 * time.Second))
}
// A file was created, renamed, deleted, or modify in the directory.
if FindNextChangeNotification(dwChangeHandles[dwWaitStatus]) == false {
log.Fatal("[dogo] Error: FindNextChangeNotification function failed.\n")
}
} else if dwWaitStatus == WAIT_TIMEOUT {
// A timeout occurred, this would happen if some value other
// than INFINITE is used in the Wait call and no changes occur.
// In a single-threaded environment you might not want an
// INFINITE wait.
fmt.Printf("[dogo] No changes in the timeout period.\n")
} else {
log.Fatal("[dogo] Error: Unhandled dwWaitStatus.\n")
}
}
}