1 |
|
|
// Copyright Joyent, Inc. and other Node contributors. |
2 |
|
|
// |
3 |
|
|
// Permission is hereby granted, free of charge, to any person obtaining a |
4 |
|
|
// copy of this software and associated documentation files (the |
5 |
|
|
// "Software"), to deal in the Software without restriction, including |
6 |
|
|
// without limitation the rights to use, copy, modify, merge, publish, |
7 |
|
|
// distribute, sublicense, and/or sell copies of the Software, and to permit |
8 |
|
|
// persons to whom the Software is furnished to do so, subject to the |
9 |
|
|
// following conditions: |
10 |
|
|
// |
11 |
|
|
// The above copyright notice and this permission notice shall be included |
12 |
|
|
// in all copies or substantial portions of the Software. |
13 |
|
|
// |
14 |
|
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS |
15 |
|
|
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
16 |
|
|
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN |
17 |
|
|
// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, |
18 |
|
|
// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR |
19 |
|
|
// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE |
20 |
|
|
// USE OR OTHER DEALINGS IN THE SOFTWARE. |
21 |
|
|
|
22 |
|
|
#ifndef SRC_THREADPOOLWORK_INL_H_ |
23 |
|
|
#define SRC_THREADPOOLWORK_INL_H_ |
24 |
|
|
|
25 |
|
|
#if defined(NODE_WANT_INTERNALS) && NODE_WANT_INTERNALS |
26 |
|
|
|
27 |
|
|
#include "node_internals.h" |
28 |
|
|
#include "tracing/trace_event.h" |
29 |
|
|
#include "util-inl.h" |
30 |
|
|
|
31 |
|
|
namespace node { |
32 |
|
|
|
33 |
|
16575 |
void ThreadPoolWork::ScheduleWork() { |
34 |
|
16575 |
env_->IncreaseWaitingRequestCounter(); |
35 |
✓✓✓✓
|
16669 |
TRACE_EVENT_NESTABLE_ASYNC_BEGIN0( |
36 |
|
|
TRACING_CATEGORY_NODE2(threadpoolwork, async), type_, this); |
37 |
|
33150 |
int status = uv_queue_work( |
38 |
|
16575 |
env_->event_loop(), |
39 |
|
|
&work_req_, |
40 |
|
16574 |
[](uv_work_t* req) { |
41 |
|
16574 |
ThreadPoolWork* self = ContainerOf(&ThreadPoolWork::work_req_, req); |
42 |
✓✓✓✓
|
16669 |
TRACE_EVENT_BEGIN0(TRACING_CATEGORY_NODE2(threadpoolwork, sync), |
43 |
|
|
self->type_); |
44 |
|
16574 |
self->DoThreadPoolWork(); |
45 |
✓✓✓✓
|
16668 |
TRACE_EVENT_END0(TRACING_CATEGORY_NODE2(threadpoolwork, sync), |
46 |
|
|
self->type_); |
47 |
|
16574 |
}, |
48 |
|
16574 |
[](uv_work_t* req, int status) { |
49 |
|
16574 |
ThreadPoolWork* self = ContainerOf(&ThreadPoolWork::work_req_, req); |
50 |
|
16574 |
self->env_->DecreaseWaitingRequestCounter(); |
51 |
✓✓✓✓
|
16667 |
TRACE_EVENT_NESTABLE_ASYNC_END1( |
52 |
|
|
TRACING_CATEGORY_NODE2(threadpoolwork, async), |
53 |
|
|
self->type_, |
54 |
|
|
self, |
55 |
|
|
"result", |
56 |
|
|
status); |
57 |
|
16574 |
self->AfterThreadPoolWork(status); |
58 |
|
33148 |
}); |
59 |
✗✓ |
16575 |
CHECK_EQ(status, 0); |
60 |
|
16575 |
} |
61 |
|
|
|
62 |
|
1 |
int ThreadPoolWork::CancelWork() { |
63 |
|
1 |
return uv_cancel(reinterpret_cast<uv_req_t*>(&work_req_)); |
64 |
|
|
} |
65 |
|
|
|
66 |
|
|
} // namespace node |
67 |
|
|
|
68 |
|
|
#endif // defined(NODE_WANT_INTERNALS) && NODE_WANT_INTERNALS |
69 |
|
|
|
70 |
|
|
#endif // SRC_THREADPOOLWORK_INL_H_ |