opal-webpack-loader 0.11.1 → 0.12.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/README.md +212 -216
- data/bin/opal-webpack-compile-server +0 -1
- data/bin/opal-webpack-windows-compile-server +7 -4
- data/bin/owl-compiler +7 -4
- data/bin/owl-gen-loadpath-cache +0 -0
- data/bin/owl-install +0 -0
- data/lib/opal-webpack-loader/installer_cli.rb +415 -415
- data/lib/opal-webpack-loader/pipe_server.rb +219 -219
- data/lib/opal-webpack-loader/templates/debug.js.erb +9 -10
- data/lib/opal-webpack-loader/templates/development.js.erb +10 -11
- data/lib/opal-webpack-loader/templates/package.json.erb +1 -1
- data/lib/opal-webpack-loader/version.rb +3 -3
- metadata +23 -37
@@ -1,219 +1,219 @@
|
|
1
|
-
require 'ffi'
|
2
|
-
|
3
|
-
module OpalWebpackLoader
|
4
|
-
module WindowsyThings
|
5
|
-
extend FFI::Library
|
6
|
-
|
7
|
-
ffi_lib :kernel32, :user32
|
8
|
-
|
9
|
-
ERROR_IO_PENDING = 997
|
10
|
-
ERROR_PIPE_CONNECTED = 535
|
11
|
-
ERROR_SUCCESS = 0
|
12
|
-
|
13
|
-
FILE_FLAG_OVERLAPPED = 0x40000000
|
14
|
-
|
15
|
-
INFINITE = 0xFFFFFFFF
|
16
|
-
INVALID_HANDLE_VALUE = FFI::Pointer.new(-1).address
|
17
|
-
|
18
|
-
PIPE_ACCESS_DUPLEX = 0x00000003
|
19
|
-
PIPE_READMODE_BYTE = 0x00000000
|
20
|
-
PIPE_READMODE_MESSAGE = 0x00000002
|
21
|
-
PIPE_TYPE_BYTE = 0x00000000
|
22
|
-
PIPE_TYPE_MESSAGE = 0x00000004
|
23
|
-
PIPE_WAIT = 0x00000000
|
24
|
-
|
25
|
-
QS_ALLINPUT = 0x04FF
|
26
|
-
|
27
|
-
typedef :uintptr_t, :handle
|
28
|
-
|
29
|
-
attach_function :ConnectNamedPipe, [:handle, :pointer], :ulong
|
30
|
-
attach_function :CreateEvent, :CreateEventA, [:pointer, :ulong, :ulong, :string], :handle
|
31
|
-
attach_function :CreateNamedPipe, :CreateNamedPipeA, [:string, :ulong, :ulong, :ulong, :ulong, :ulong, :ulong, :pointer], :handle
|
32
|
-
attach_function :DisconnectNamedPipe, [:handle], :bool
|
33
|
-
attach_function :FlushFileBuffers, [:handle], :bool
|
34
|
-
attach_function :GetLastError, [], :ulong
|
35
|
-
attach_function :GetOverlappedResult, [:handle, :pointer, :pointer, :bool], :bool
|
36
|
-
attach_function :MsgWaitForMultipleObjects, [:ulong, :pointer, :ulong, :ulong, :ulong], :ulong
|
37
|
-
attach_function :ReadFile, [:handle, :buffer_out, :ulong, :pointer, :pointer], :bool
|
38
|
-
attach_function :SetEvent, [:handle], :bool
|
39
|
-
attach_function :WaitForMultipleObjects, [:ulong, :pointer, :ulong, :ulong], :ulong
|
40
|
-
attach_function :WriteFile, [:handle, :buffer_in, :ulong, :pointer, :pointer], :bool
|
41
|
-
end
|
42
|
-
|
43
|
-
class PipeServer
|
44
|
-
include OpalWebpackLoader::WindowsyThings
|
45
|
-
|
46
|
-
CONNECTING_STATE = 0
|
47
|
-
READING_STATE = 1
|
48
|
-
WRITING_STATE = 2
|
49
|
-
INSTANCES = 4
|
50
|
-
PIPE_TIMEOUT = 5000
|
51
|
-
BUFFER_SIZE = 65536
|
52
|
-
|
53
|
-
class Overlapped < FFI::Struct
|
54
|
-
layout(
|
55
|
-
:Internal, :uintptr_t,
|
56
|
-
:InternalHigh, :uintptr_t,
|
57
|
-
:Offset, :ulong,
|
58
|
-
:OffsetHigh, :ulong,
|
59
|
-
:hEvent, :uintptr_t
|
60
|
-
)
|
61
|
-
end
|
62
|
-
|
63
|
-
def initialize(pipe_name, instances = 4, &block)
|
64
|
-
@run_block = block
|
65
|
-
@full_pipe_name = "\\\\.\\pipe\\#{pipe_name}"
|
66
|
-
@instances = instances
|
67
|
-
@events = []
|
68
|
-
@events_pointer = FFI::MemoryPointer.new(:uintptr_t, @instances)
|
69
|
-
@pipes = []
|
70
|
-
end
|
71
|
-
|
72
|
-
def run
|
73
|
-
create_instances
|
74
|
-
while_loop
|
75
|
-
end
|
76
|
-
|
77
|
-
private
|
78
|
-
|
79
|
-
def create_instances
|
80
|
-
(0...@instances).each do |i|
|
81
|
-
@events[i] = CreateEvent(nil, 1, 1, nil)
|
82
|
-
raise "CreateEvent failed with #{GetLastError()}" unless @events[i]
|
83
|
-
|
84
|
-
overlap = Overlapped.new
|
85
|
-
overlap[:hEvent] = @events[i]
|
86
|
-
|
87
|
-
@pipes[i] = { overlap: overlap, instance: nil, request: FFI::Buffer.new(1, BUFFER_SIZE), bytes_read: 0, reply: FFI::Buffer.new(1, BUFFER_SIZE), bytes_to_write: 0, state: nil, pending_io: false }
|
88
|
-
@pipes[i][:instance] = CreateNamedPipe(@full_pipe_name,
|
89
|
-
PIPE_ACCESS_DUPLEX | FILE_FLAG_OVERLAPPED,
|
90
|
-
PIPE_TYPE_MESSAGE | PIPE_READMODE_MESSAGE | PIPE_WAIT,
|
91
|
-
@instances,
|
92
|
-
BUFFER_SIZE,
|
93
|
-
BUFFER_SIZE,
|
94
|
-
PIPE_TIMEOUT,
|
95
|
-
nil)
|
96
|
-
|
97
|
-
raise "CreateNamedPipe failed with #{GetLastError()}" if @pipes[i][:instance] == INVALID_HANDLE_VALUE
|
98
|
-
@pipes[i][:pending_io] = connect_to_new_client(i)
|
99
|
-
@pipes[i][:state] = @pipes[i][:pending_io] ? CONNECTING_STATE : READING_STATE
|
100
|
-
end
|
101
|
-
@events_pointer.write_array_of_ulong_long(@events)
|
102
|
-
nil
|
103
|
-
end
|
104
|
-
|
105
|
-
def while_loop
|
106
|
-
while true
|
107
|
-
i = MsgWaitForMultipleObjects(@instances, @events_pointer, 0, INFINITE, QS_ALLINPUT)
|
108
|
-
# Having this STDOUT.putc is essential, otherwise there is a tendency to block within MsgWaitForMultipleObjects ...
|
109
|
-
STDOUT.putc "."
|
110
|
-
# ... because the ruby interpreter is waiting for objects too on Windows. Thats why we wait for QS_ALLINPUT and
|
111
|
-
# with STDOUT.putc give back control to the ruby interpreter that it can handle its things.
|
112
|
-
if i < 0 || i > (@instances - 1)
|
113
|
-
STDERR.puts "Pipe index out of range. Maybe a error occured."
|
114
|
-
next
|
115
|
-
end
|
116
|
-
|
117
|
-
if @pipes[i][:pending_io]
|
118
|
-
bytes_transferred = FFI::MemoryPointer.new(:ulong)
|
119
|
-
success = GetOverlappedResult(@pipes[i][:instance], @pipes[i][:overlap], bytes_transferred, false)
|
120
|
-
|
121
|
-
case @pipes[i][:state]
|
122
|
-
when CONNECTING_STATE
|
123
|
-
raise "Error #{GetLastError()}" unless success
|
124
|
-
@pipes[i][:state] = READING_STATE
|
125
|
-
when READING_STATE
|
126
|
-
if !success || bytes_transferred.read_ulong == 0
|
127
|
-
disconnect_and_reconnect(i)
|
128
|
-
next
|
129
|
-
else
|
130
|
-
@pipes[i][:bytes_read] = bytes_transferred.read_ulong
|
131
|
-
@pipes[i][:state] = WRITING_STATE
|
132
|
-
end
|
133
|
-
when WRITING_STATE
|
134
|
-
if !success || bytes_transferred.read_ulong != @pipes[i][:bytes_to_write]
|
135
|
-
disconnect_and_reconnect(i)
|
136
|
-
next
|
137
|
-
else
|
138
|
-
@pipes[i][:state] = READING_STATE
|
139
|
-
end
|
140
|
-
else
|
141
|
-
raise "Invalid pipe state."
|
142
|
-
end
|
143
|
-
end
|
144
|
-
|
145
|
-
case @pipes[i][:state]
|
146
|
-
when READING_STATE
|
147
|
-
bytes_read = FFI::MemoryPointer.new(:ulong)
|
148
|
-
success = ReadFile(@pipes[i][:instance], @pipes[i][:request], BUFFER_SIZE, bytes_read, @pipes[i][:overlap].to_ptr)
|
149
|
-
if success && bytes_read.read_ulong != 0
|
150
|
-
@pipes[i][:pending_io] = false
|
151
|
-
@pipes[i][:state] = WRITING_STATE
|
152
|
-
next
|
153
|
-
end
|
154
|
-
|
155
|
-
err = GetLastError()
|
156
|
-
if !success && err == ERROR_IO_PENDING
|
157
|
-
@pipes[i][:pending_io] = true
|
158
|
-
next
|
159
|
-
end
|
160
|
-
|
161
|
-
disconnect_and_reconnect(i)
|
162
|
-
when WRITING_STATE
|
163
|
-
@pipes[i][:reply] = @run_block.call(@pipes[i][:request].get_string(0))
|
164
|
-
@pipes[i][:bytes_to_write] = @pipes[i][:reply].bytesize
|
165
|
-
bytes_written = FFI::MemoryPointer.new(:ulong)
|
166
|
-
success = WriteFile(@pipes[i][:instance], @pipes[i][:reply], @pipes[i][:bytes_to_write], bytes_written, @pipes[i][:overlap].to_ptr)
|
167
|
-
|
168
|
-
if success && bytes_written.read_ulong == @pipes[i][:bytes_to_write]
|
169
|
-
@pipes[i][:pending_io] = false
|
170
|
-
@pipes[i][:state] = READING_STATE
|
171
|
-
next
|
172
|
-
end
|
173
|
-
|
174
|
-
err = GetLastError()
|
175
|
-
|
176
|
-
if !success && err == ERROR_IO_PENDING
|
177
|
-
@pipes[i][:pending_io] = true
|
178
|
-
next
|
179
|
-
end
|
180
|
-
|
181
|
-
disconnect_and_reconnect(i)
|
182
|
-
else
|
183
|
-
raise "Invalid pipe state."
|
184
|
-
end
|
185
|
-
end
|
186
|
-
end
|
187
|
-
|
188
|
-
def disconnect_and_reconnect(i)
|
189
|
-
FlushFileBuffers(@pipes[i][:instance])
|
190
|
-
STDERR.puts("DisconnectNamedPipe failed with #{GetLastError()}") if !DisconnectNamedPipe(@pipes[i][:instance])
|
191
|
-
|
192
|
-
@pipes[i][:pending_io] = connect_to_new_client(i)
|
193
|
-
|
194
|
-
@pipes[i][:state] = @pipes[i][:pending_io] ? CONNECTING_STATE : READING_STATE
|
195
|
-
end
|
196
|
-
|
197
|
-
def connect_to_new_client(i)
|
198
|
-
pending_io = false
|
199
|
-
@pipes[i][:request].clear
|
200
|
-
@pipes[i][:reply].clear
|
201
|
-
connected = ConnectNamedPipe(@pipes[i][:instance], @pipes[i][:overlap].to_ptr)
|
202
|
-
last_error = GetLastError()
|
203
|
-
raise "ConnectNamedPipe failed with #{last_error} - #{connected}" if connected != 0
|
204
|
-
|
205
|
-
case last_error
|
206
|
-
when ERROR_IO_PENDING
|
207
|
-
pending_io = true
|
208
|
-
when ERROR_PIPE_CONNECTED
|
209
|
-
SetEvent(@pipes[i][:overlap][:hEvent])
|
210
|
-
when ERROR_SUCCESS
|
211
|
-
pending_io = true
|
212
|
-
else
|
213
|
-
raise "ConnectNamedPipe failed with error #{last_error}"
|
214
|
-
end
|
215
|
-
|
216
|
-
pending_io
|
217
|
-
end
|
218
|
-
end
|
219
|
-
end
|
1
|
+
require 'ffi'
|
2
|
+
|
3
|
+
module OpalWebpackLoader
|
4
|
+
module WindowsyThings
|
5
|
+
extend FFI::Library
|
6
|
+
|
7
|
+
ffi_lib :kernel32, :user32
|
8
|
+
|
9
|
+
ERROR_IO_PENDING = 997
|
10
|
+
ERROR_PIPE_CONNECTED = 535
|
11
|
+
ERROR_SUCCESS = 0
|
12
|
+
|
13
|
+
FILE_FLAG_OVERLAPPED = 0x40000000
|
14
|
+
|
15
|
+
INFINITE = 0xFFFFFFFF
|
16
|
+
INVALID_HANDLE_VALUE = FFI::Pointer.new(-1).address
|
17
|
+
|
18
|
+
PIPE_ACCESS_DUPLEX = 0x00000003
|
19
|
+
PIPE_READMODE_BYTE = 0x00000000
|
20
|
+
PIPE_READMODE_MESSAGE = 0x00000002
|
21
|
+
PIPE_TYPE_BYTE = 0x00000000
|
22
|
+
PIPE_TYPE_MESSAGE = 0x00000004
|
23
|
+
PIPE_WAIT = 0x00000000
|
24
|
+
|
25
|
+
QS_ALLINPUT = 0x04FF
|
26
|
+
|
27
|
+
typedef :uintptr_t, :handle
|
28
|
+
|
29
|
+
attach_function :ConnectNamedPipe, [:handle, :pointer], :ulong
|
30
|
+
attach_function :CreateEvent, :CreateEventA, [:pointer, :ulong, :ulong, :string], :handle
|
31
|
+
attach_function :CreateNamedPipe, :CreateNamedPipeA, [:string, :ulong, :ulong, :ulong, :ulong, :ulong, :ulong, :pointer], :handle
|
32
|
+
attach_function :DisconnectNamedPipe, [:handle], :bool
|
33
|
+
attach_function :FlushFileBuffers, [:handle], :bool
|
34
|
+
attach_function :GetLastError, [], :ulong
|
35
|
+
attach_function :GetOverlappedResult, [:handle, :pointer, :pointer, :bool], :bool
|
36
|
+
attach_function :MsgWaitForMultipleObjects, [:ulong, :pointer, :ulong, :ulong, :ulong], :ulong
|
37
|
+
attach_function :ReadFile, [:handle, :buffer_out, :ulong, :pointer, :pointer], :bool
|
38
|
+
attach_function :SetEvent, [:handle], :bool
|
39
|
+
attach_function :WaitForMultipleObjects, [:ulong, :pointer, :ulong, :ulong], :ulong
|
40
|
+
attach_function :WriteFile, [:handle, :buffer_in, :ulong, :pointer, :pointer], :bool
|
41
|
+
end
|
42
|
+
|
43
|
+
class PipeServer
|
44
|
+
include OpalWebpackLoader::WindowsyThings
|
45
|
+
|
46
|
+
CONNECTING_STATE = 0
|
47
|
+
READING_STATE = 1
|
48
|
+
WRITING_STATE = 2
|
49
|
+
INSTANCES = 4
|
50
|
+
PIPE_TIMEOUT = 5000
|
51
|
+
BUFFER_SIZE = 65536
|
52
|
+
|
53
|
+
class Overlapped < FFI::Struct
|
54
|
+
layout(
|
55
|
+
:Internal, :uintptr_t,
|
56
|
+
:InternalHigh, :uintptr_t,
|
57
|
+
:Offset, :ulong,
|
58
|
+
:OffsetHigh, :ulong,
|
59
|
+
:hEvent, :uintptr_t
|
60
|
+
)
|
61
|
+
end
|
62
|
+
|
63
|
+
def initialize(pipe_name, instances = 4, &block)
|
64
|
+
@run_block = block
|
65
|
+
@full_pipe_name = "\\\\.\\pipe\\#{pipe_name}"
|
66
|
+
@instances = instances
|
67
|
+
@events = []
|
68
|
+
@events_pointer = FFI::MemoryPointer.new(:uintptr_t, @instances)
|
69
|
+
@pipes = []
|
70
|
+
end
|
71
|
+
|
72
|
+
def run
|
73
|
+
create_instances
|
74
|
+
while_loop
|
75
|
+
end
|
76
|
+
|
77
|
+
private
|
78
|
+
|
79
|
+
def create_instances
|
80
|
+
(0...@instances).each do |i|
|
81
|
+
@events[i] = CreateEvent(nil, 1, 1, nil)
|
82
|
+
raise "CreateEvent failed with #{GetLastError()}" unless @events[i]
|
83
|
+
|
84
|
+
overlap = Overlapped.new
|
85
|
+
overlap[:hEvent] = @events[i]
|
86
|
+
|
87
|
+
@pipes[i] = { overlap: overlap, instance: nil, request: FFI::Buffer.new(1, BUFFER_SIZE), bytes_read: 0, reply: FFI::Buffer.new(1, BUFFER_SIZE), bytes_to_write: 0, state: nil, pending_io: false }
|
88
|
+
@pipes[i][:instance] = CreateNamedPipe(@full_pipe_name,
|
89
|
+
PIPE_ACCESS_DUPLEX | FILE_FLAG_OVERLAPPED,
|
90
|
+
PIPE_TYPE_MESSAGE | PIPE_READMODE_MESSAGE | PIPE_WAIT,
|
91
|
+
@instances,
|
92
|
+
BUFFER_SIZE,
|
93
|
+
BUFFER_SIZE,
|
94
|
+
PIPE_TIMEOUT,
|
95
|
+
nil)
|
96
|
+
|
97
|
+
raise "CreateNamedPipe failed with #{GetLastError()}" if @pipes[i][:instance] == INVALID_HANDLE_VALUE
|
98
|
+
@pipes[i][:pending_io] = connect_to_new_client(i)
|
99
|
+
@pipes[i][:state] = @pipes[i][:pending_io] ? CONNECTING_STATE : READING_STATE
|
100
|
+
end
|
101
|
+
@events_pointer.write_array_of_ulong_long(@events)
|
102
|
+
nil
|
103
|
+
end
|
104
|
+
|
105
|
+
def while_loop
|
106
|
+
while true
|
107
|
+
i = MsgWaitForMultipleObjects(@instances, @events_pointer, 0, INFINITE, QS_ALLINPUT)
|
108
|
+
# Having this STDOUT.putc is essential, otherwise there is a tendency to block within MsgWaitForMultipleObjects ...
|
109
|
+
STDOUT.putc "."
|
110
|
+
# ... because the ruby interpreter is waiting for objects too on Windows. Thats why we wait for QS_ALLINPUT and
|
111
|
+
# with STDOUT.putc give back control to the ruby interpreter that it can handle its things.
|
112
|
+
if i < 0 || i > (@instances - 1)
|
113
|
+
STDERR.puts "Pipe index out of range. Maybe a error occured."
|
114
|
+
next
|
115
|
+
end
|
116
|
+
|
117
|
+
if @pipes[i][:pending_io]
|
118
|
+
bytes_transferred = FFI::MemoryPointer.new(:ulong)
|
119
|
+
success = GetOverlappedResult(@pipes[i][:instance], @pipes[i][:overlap], bytes_transferred, false)
|
120
|
+
|
121
|
+
case @pipes[i][:state]
|
122
|
+
when CONNECTING_STATE
|
123
|
+
raise "Error #{GetLastError()}" unless success
|
124
|
+
@pipes[i][:state] = READING_STATE
|
125
|
+
when READING_STATE
|
126
|
+
if !success || bytes_transferred.read_ulong == 0
|
127
|
+
disconnect_and_reconnect(i)
|
128
|
+
next
|
129
|
+
else
|
130
|
+
@pipes[i][:bytes_read] = bytes_transferred.read_ulong
|
131
|
+
@pipes[i][:state] = WRITING_STATE
|
132
|
+
end
|
133
|
+
when WRITING_STATE
|
134
|
+
if !success || bytes_transferred.read_ulong != @pipes[i][:bytes_to_write]
|
135
|
+
disconnect_and_reconnect(i)
|
136
|
+
next
|
137
|
+
else
|
138
|
+
@pipes[i][:state] = READING_STATE
|
139
|
+
end
|
140
|
+
else
|
141
|
+
raise "Invalid pipe state."
|
142
|
+
end
|
143
|
+
end
|
144
|
+
|
145
|
+
case @pipes[i][:state]
|
146
|
+
when READING_STATE
|
147
|
+
bytes_read = FFI::MemoryPointer.new(:ulong)
|
148
|
+
success = ReadFile(@pipes[i][:instance], @pipes[i][:request], BUFFER_SIZE, bytes_read, @pipes[i][:overlap].to_ptr)
|
149
|
+
if success && bytes_read.read_ulong != 0
|
150
|
+
@pipes[i][:pending_io] = false
|
151
|
+
@pipes[i][:state] = WRITING_STATE
|
152
|
+
next
|
153
|
+
end
|
154
|
+
|
155
|
+
err = GetLastError()
|
156
|
+
if !success && err == ERROR_IO_PENDING
|
157
|
+
@pipes[i][:pending_io] = true
|
158
|
+
next
|
159
|
+
end
|
160
|
+
|
161
|
+
disconnect_and_reconnect(i)
|
162
|
+
when WRITING_STATE
|
163
|
+
@pipes[i][:reply] = @run_block.call(@pipes[i][:request].get_string(0))
|
164
|
+
@pipes[i][:bytes_to_write] = @pipes[i][:reply].bytesize
|
165
|
+
bytes_written = FFI::MemoryPointer.new(:ulong)
|
166
|
+
success = WriteFile(@pipes[i][:instance], @pipes[i][:reply], @pipes[i][:bytes_to_write], bytes_written, @pipes[i][:overlap].to_ptr)
|
167
|
+
|
168
|
+
if success && bytes_written.read_ulong == @pipes[i][:bytes_to_write]
|
169
|
+
@pipes[i][:pending_io] = false
|
170
|
+
@pipes[i][:state] = READING_STATE
|
171
|
+
next
|
172
|
+
end
|
173
|
+
|
174
|
+
err = GetLastError()
|
175
|
+
|
176
|
+
if !success && err == ERROR_IO_PENDING
|
177
|
+
@pipes[i][:pending_io] = true
|
178
|
+
next
|
179
|
+
end
|
180
|
+
|
181
|
+
disconnect_and_reconnect(i)
|
182
|
+
else
|
183
|
+
raise "Invalid pipe state."
|
184
|
+
end
|
185
|
+
end
|
186
|
+
end
|
187
|
+
|
188
|
+
def disconnect_and_reconnect(i)
|
189
|
+
FlushFileBuffers(@pipes[i][:instance])
|
190
|
+
STDERR.puts("DisconnectNamedPipe failed with #{GetLastError()}") if !DisconnectNamedPipe(@pipes[i][:instance])
|
191
|
+
|
192
|
+
@pipes[i][:pending_io] = connect_to_new_client(i)
|
193
|
+
|
194
|
+
@pipes[i][:state] = @pipes[i][:pending_io] ? CONNECTING_STATE : READING_STATE
|
195
|
+
end
|
196
|
+
|
197
|
+
def connect_to_new_client(i)
|
198
|
+
pending_io = false
|
199
|
+
@pipes[i][:request].clear
|
200
|
+
@pipes[i][:reply].clear
|
201
|
+
connected = ConnectNamedPipe(@pipes[i][:instance], @pipes[i][:overlap].to_ptr)
|
202
|
+
last_error = GetLastError()
|
203
|
+
raise "ConnectNamedPipe failed with #{last_error} - #{connected}" if connected != 0
|
204
|
+
|
205
|
+
case last_error
|
206
|
+
when ERROR_IO_PENDING
|
207
|
+
pending_io = true
|
208
|
+
when ERROR_PIPE_CONNECTED
|
209
|
+
SetEvent(@pipes[i][:overlap][:hEvent])
|
210
|
+
when ERROR_SUCCESS
|
211
|
+
pending_io = true
|
212
|
+
else
|
213
|
+
raise "ConnectNamedPipe failed with error #{last_error}"
|
214
|
+
end
|
215
|
+
|
216
|
+
pending_io
|
217
|
+
end
|
218
|
+
end
|
219
|
+
end
|
@@ -99,26 +99,25 @@ const common_config = {
|
|
99
99
|
devServer: {
|
100
100
|
<%= dev_server_before %>
|
101
101
|
open: false,
|
102
|
-
lazy: false,
|
103
102
|
port: 3035,
|
104
103
|
hot: true,
|
105
|
-
// hotOnly: true,
|
106
|
-
inline: true,
|
107
104
|
https: false,
|
108
|
-
|
105
|
+
allowedHosts: 'all',
|
109
106
|
headers: {
|
110
107
|
"Access-Control-Allow-Origin": "*",
|
111
108
|
"Access-Control-Allow-Methods": "GET, POST, PUT, DELETE, PATCH, OPTIONS",
|
112
109
|
"Access-Control-Allow-Headers": "X-Requested-With, content-type, Authorization"
|
113
110
|
},
|
114
|
-
|
115
|
-
|
116
|
-
|
117
|
-
|
111
|
+
static: {
|
112
|
+
directory: path.resolve(__dirname, 'public'),
|
113
|
+
watch: {
|
114
|
+
// in case of problems with hot reloading uncomment the following two lines:
|
115
|
+
// aggregateTimeout: 250,
|
116
|
+
// poll: 50,
|
118
117
|
ignored: /\bnode_modules\b/
|
118
|
+
}
|
119
119
|
},
|
120
|
-
|
121
|
-
useLocalIp: false
|
120
|
+
host: 'localhost'
|
122
121
|
}
|
123
122
|
};
|
124
123
|
|