MyTask is a modern, lightweight task management application designed for developers who prefer working in a terminal environment. Built with Go, it combines the simplicity of command-line interfaces with powerful task management features.
In a world of complex task management solutions, MyTask stands out by embracing Unix philosophy: do one thing and do it well. Whether you're organizing code-related tasks, managing bug fixes, or planning features, MyTask provides a distraction-free environment for staying productive
mytask/ ├── cmd/ │ └── add.go # Add a task │ └── delete.go # Delete task │ └── help.go # View commands │ └── init.go # Initialize │ └── list.go # List tasks │ └── update.go # Update task status │ └── util.go # Reuse package │ ├── todo │ └── todo.go # Switch case impl │ ├── README.md ├── go.mod ├── go.sum └── main.go # Main file
mkdir mytask
cd mytask
go mod init github.com/dev-dhanushkumar/golang-projects/mytask
go get github.com/alexeyco/simpletable
Adding a new task to a todo list. It utilizes the flag package to handle command-line arguments and the todo package (likely located elsewhere) to manage the actual todo list data.
func AddTask(todos *todo.Todos, args []string) { // Define the "add" subCommand to add todo item addCmd := flag.NewFlagSet("add", flag.ExitOnError) addTask := addCmd.String("task", "", "The content of new todo item") // Define an optional "--cat" flag for the todo item addCat := addCmd.String("cat", "Uncategorized", "The category of the todo item") // Parse the argument for the "add" subcommand addCmd.Parse(args) // Check if the required todo text was provided if len(*addTask) == 0 { fmt.Println("Error: the --task flag is required for the 'add' subcommand.") os.Exit(1) } //Get the todo text from the positional argument todos.Add(*addTask, *addCat) err := todos.Store(GetJsonFile()) if err != nil { log.Fatal(err) } todos.Print(2, "") fmt.Println("Todo item added successfully.") }
Deleting existing tasks from the todo list. It likely uses the flag package to handle command-line arguments and interacts with the todo package to manage the todo list data.
func DeleteTask(todos *todo.Todos, args []string) { deleteCmd := flag.NewFlagSet("delete", flag.ExitOnError) // If no --id=1 flag defined todo will default to 0 deleteID := deleteCmd.Int("id", 0, "The id of todo to be deleted") // Parse the argument for the "delete" subcommand deleteCmd.Parse(args) err := todos.Delete(*deleteID) if err != nil { log.Fatal(err) } err = todos.Store(GetJsonFile()) if err != nil { log.Fatal(err) } todos.Print(2, "") fmt.Println("Todo item deleted successfully.") }
In the context of a command-line todo list application like MyTask, the "list" command typically refers to the action of displaying the current list of todo items to the user. Based on below description we display the our task list.
mytask/ ├── cmd/ │ └── add.go # Add a task │ └── delete.go # Delete task │ └── help.go # View commands │ └── init.go # Initialize │ └── list.go # List tasks │ └── update.go # Update task status │ └── util.go # Reuse package │ ├── todo │ └── todo.go # Switch case impl │ ├── README.md ├── go.mod ├── go.sum └── main.go # Main file
mkdir mytask
This functionality for updating an existing task in the todo list and update the task status. It utilizes the flag package to handle command-line arguments and interacts with the todo package (likely located elsewhere) to manage the actual todo list data.
cd mytask
For detailed installation and usage instructions, please refer to the README.md file in the project repository: [https://github.com/dev-dhanushkumar/Golang-Projects/tree/main/golang_task]
This project successfully creates the core functionality of the MyTask application. Through this process, I gained valuable experience in Go programming, command-line interface development, and project management. I learned to overcome challenges like implementing efficient task storage, File parse, Local Storage and effectively utilize the Go standard library. This project serves as a valuable learning experience and a foundation for further development in the area of task management applications.
The above is the detailed content of MyTask ToDo CLI Tool.... For more information, please follow other related articles on the PHP Chinese website!