-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathruntime_taskqueue_options.go
More file actions
58 lines (51 loc) · 1.85 KB
/
runtime_taskqueue_options.go
File metadata and controls
58 lines (51 loc) · 1.85 KB
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
/*
* This file is part of Golaxy Distributed Service Development Framework.
*
* Golaxy Distributed Service Development Framework is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 2.1 of the License, or
* (at your option) any later version.
*
* Golaxy Distributed Service Development Framework is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with Golaxy Distributed Service Development Framework. If not, see <http://www.gnu.org/licenses/>.
*
* Copyright (c) 2024 pangdogs.
*/
package core
import (
"git.golaxy.org/core/utils/exception"
"git.golaxy.org/core/utils/option"
)
// TaskQueueOptions 任务处理流水线的所有选项
type TaskQueueOptions struct {
Unbounded bool // 是否无上限
Capacity int // 流水线大小
}
type _TaskQueueOption struct{}
// Default 默认值
func (_TaskQueueOption) Default() option.Setting[TaskQueueOptions] {
return func(options *TaskQueueOptions) {
With.TaskQueue.Unbounded(true).Apply(options)
With.TaskQueue.Capacity(128).Apply(options)
}
}
// Unbounded 是否无上限
func (_TaskQueueOption) Unbounded(b bool) option.Setting[TaskQueueOptions] {
return func(options *TaskQueueOptions) {
options.Unbounded = b
}
}
// Capacity 流水线大小
func (_TaskQueueOption) Capacity(cap int) option.Setting[TaskQueueOptions] {
return func(options *TaskQueueOptions) {
if cap <= 0 {
exception.Panicf("%w: %w: Capacity must be greater than 0", ErrRuntime, exception.ErrArgs)
}
options.Capacity = cap
}
}