Rumah >pembangunan bahagian belakang >Golang >Alat CLI MyTask ToDo...

Alat CLI MyTask ToDo...

DDD
DDDasal
2024-12-25 15:54:14417semak imbas

pengenalan

MyTask ialah aplikasi pengurusan tugasan moden dan ringan yang direka untuk pembangun yang lebih suka bekerja dalam persekitaran terminal. Dibina dengan Go, ia menggabungkan kesederhanaan antara muka baris arahan dengan ciri pengurusan tugas yang berkuasa.

MyTask ToDo CLI Tool...

Mengapa MyTask?

Dalam dunia penyelesaian pengurusan tugas yang kompleks, MyTask menonjol dengan mengamalkan falsafah Unix: lakukan satu perkara dan lakukannya dengan baik. Sama ada anda mengatur tugas berkaitan kod, mengurus pembetulan pepijat atau merancang ciri, MyTask menyediakan persekitaran bebas gangguan untuk kekal produktif

Ciri-ciri Utama

  • Minimum dan Cepat: Ditulis dalam Go untuk prestasi luar biasa dan penggunaan sumber yang rendah
  • Terminal-Pertama: Penyepaduan lancar dengan aliran kerja terminal sedia ada anda
  • Arahan Gaya Git: Sintaks perintah yang biasa digunakan untuk pembangun (tambahan tugasan saya, senarai tugasan saya, dll.)
  • Merentas Platform: Berjalan pada Linux, macOS dan Windows
  • Kemudahalihan Data: Simpan tugas anda dalam fail teks biasa, mudah disegerakkan merentas peranti
  • Boleh disesuaikan: Pilihan konfigurasi yang luas sambil mengekalkan kesederhanaan

Ketegangan Projek:

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

Persediaan Projek

  • Buat Direktori Projek:
mkdir mytask
  • Navigasi ke direktori:
cd mytask
  • Memulakan Modul Go:
go mod init github.com/dev-dhanushkumar/golang-projects/mytask
  • Pakej SimpleTable: Simpletable ialah perpustakaan Go yang ringkas dan ringan untuk mencipta jadual CLI yang cantik. Ia amat sesuai untuk aplikasi pengurusan tugas kami kerana ia menyediakan output yang bersih dan berformat untuk penyenaraian tugas.
 go get github.com/alexeyco/simpletable
  • Buat folder dan Fail berdasarkan struktur Projek: Struktur fail ini menyediakan asas yang kukuh untuk projek anda.

Perlaksanaan

1. Tambah Tugasan

Menambahkan tugasan baharu pada senarai tugasan. Ia menggunakan pakej bendera untuk mengendalikan hujah baris perintah dan pakej todo (kemungkinan terletak di tempat lain) untuk mengurus data senarai todo sebenar.

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. Padam Tugas

Memadamkan tugasan sedia ada daripada senarai tugasan. Ia berkemungkinan menggunakan pakej bendera untuk mengendalikan hujah baris perintah dan berinteraksi dengan pakej todo untuk mengurus data senarai 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. Senaraikan Tugas

Dalam konteks aplikasi senarai tugasan baris perintah seperti MyTask, arahan "senarai" biasanya merujuk kepada tindakan memaparkan senarai item tugasan semasa kepada pengguna. Berdasarkan penerangan di bawah, kami memaparkan senarai tugas kami.

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
  • Contoh:
mkdir mytask

4. Kemas Kini Tugas

Fungsi ini untuk mengemas kini tugasan sedia ada dalam senarai tugasan dan mengemas kini status tugasan. Ia menggunakan pakej bendera untuk mengendalikan hujah baris perintah dan berinteraksi dengan pakej todo (kemungkinan terletak di tempat lain) untuk mengurus data senarai todo sebenar.

cd mytask

Pemasangan dan Penggunaan:

Untuk arahan pemasangan dan penggunaan terperinci, sila rujuk fail README.md dalam repositori projek: [https://github.com/dev-dhanushkumar/Golang-Projects/tree/main/golang_task]

Kesimpulan

Projek ini berjaya mencipta fungsi teras aplikasi MyTask. Melalui proses ini, saya memperoleh pengalaman berharga dalam pengaturcaraan Go, pembangunan antara muka baris arahan dan pengurusan projek. Saya belajar untuk mengatasi cabaran seperti melaksanakan storan tugas yang cekap, Parse Fail, Storan Setempat dan menggunakan pustaka standard Go dengan berkesan. Projek ini berfungsi sebagai pengalaman pembelajaran yang berharga dan asas untuk pembangunan selanjutnya dalam bidang aplikasi pengurusan tugas.

Atas ialah kandungan terperinci Alat CLI MyTask ToDo.... Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn