/* * Minio Cloud Storage, (C) 2015 Minio, Inc. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package tasker // Command is number that uniquely identifies a command function. type Command uint8 // Enumerate the task commands. const ( // CmdNOOP does nothing. It is a default placeholder. Uninitialized variable of this type will point to NOOP command by default. CmdNOOP Command = iota // CmdSignalEnd gracefully ends current task. Never ending tasks (loop over) or Batched jobs will not take the next iteration, // but may finish the current state to completion. CmdSignalEnd // CmdSignalAbort ends the current task at hand immediately. It may still cleanup dangling issues quickly. CmdSignalAbort // CmdSignalSuspend suspends the current task. CmdSignalSuspend // CmdSignalResume resumes a suspended task. CmdSignalResume // CmdPriorityLow is optimized to conserve resources and complete the task at a slow pace. This option is ideal for batch processed tasks. CmdPriorityLow // CmdPriorityMedium is the default priority. It is a balanced option between resources and speed. CmdPriorityMedium // CmdPriorityHigh is optimized for speed. This option is ideal for short lived tasks (like meta-data related) that are latency sensitive. Use this option wisely. CmdPriorityHigh // CmdPrioritySuper is an exclusive priority. All tasks with priority lower than Super (including High) are paused // temporarily until this task completes. Anytime you consider using this priority level, please seek for approval. CmdPrioritySuper )