首页 > 后端开发 > Golang > MyTask ToDo CLI 工具...

MyTask ToDo CLI 工具...

DDD
发布: 2024-12-25 15:54:14
原创
408 人浏览过

介绍

MyTask 是一款现代的轻量级任务管理应用程序,专为喜欢在终端环境中工作的开发人员而设计。它使用 Go 构建,结合了命令行界面的简单性和强大的任务管理功能。

MyTask ToDo CLI Tool...

为什么选择我的任务?

在复杂任务管理解决方案的世界中,MyTask 通过拥抱 Unix 哲学而脱颖而出:做一件事并把它做好。无论您是组织与代码相关的任务、管理错误修复还是规划功能,MyTask 都能提供一个无干扰的环境来保持高效

主要特点

  • 最小且快速: 用 Go 编写,具有卓越的性能和低资源使用率
  • 终端优先:与您现有的终端工作流程无缝集成
  • Git 风格命令: 开发人员熟悉的命令语法(mytask add、mytask list 等)
  • 跨平台: 可在 Linux、macOS 和 Windows 上运行
  • 数据可移植性:将您的任务存储在纯文本文件中,轻松跨设备同步
  • 可定制:广泛的配置选项,同时保持简单性

项目规模:

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 模块:
go mod init github.com/dev-dhanushkumar/golang-projects/mytask
登录后复制
  • SimpleTable 套餐: Simpletable 是一个简单、轻量级的 Go 库,用于创建漂亮的 CLI 表。它特别适合我们的任务管理应用程序,因为它为任务列表提供干净、格式化的输出。
 go get github.com/alexeyco/simpletable
登录后复制
  • 根据项目结构创建文件夹和文件:此文件结构为您的项目提供了坚实的基础。

执行

1. 添加任务

将新任务添加到待办事项列表中。它利用 flag 包来处理命令行参数,并利用 todo 包(可能位于其他地方)来管理实际的待办事项列表数据。

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.")
}
登录后复制

2. 删除任务

从待办事项列表中删除现有任务。它可能使用 flag 包来处理命令行参数,并与 todo 包交互来管理待办事项列表数据。

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.")
}
登录后复制

3. 列出任务

在像 MyTask 这样的命令行待办事项列表应用程序的上下文中,“列表”命令通常指的是向用户显示当前待办事项列表的操作。根据以下描述,我们显示我们的任务列表。

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
登录后复制
登录后复制

4. 更新任务

此功能用于更新待办事项列表中的现有任务并更新任务状态。它利用 flag 包来处理命令行参数,并与 todo 包(可能位于其他地方)交互来管理实际的待办事项列表数据。

cd mytask
登录后复制
登录后复制

安装与使用:

详细的安装和使用说明,请参考项目仓库中的README.md文件:[https://github.com/dev-dhanushkumar/Golang-Projects/tree/main/golang_task]

结论

该项目成功创建了 MyTask 应用程序的核心功能。通过这个过程,我获得了Go编程、命令行界面开发和项目管理方面的宝贵经验。我学会了克服实现高效任务存储、文件解析、本地存储等挑战,并有效利用Go标准库。该项目是宝贵的学习经验,也是任务管理应用程序领域进一步开发的基础。

以上是MyTask ToDo CLI 工具...的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:dev.to
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板