Heim >Backend-Entwicklung >Golang >MyTask ToDo CLI-Tool...

MyTask ToDo CLI-Tool...

DDD
DDDOriginal
2024-12-25 15:54:14471Durchsuche

Einführung

MyTask ist eine moderne, leichte Aufgabenverwaltungsanwendung, die für Entwickler entwickelt wurde, die lieber in einer Terminalumgebung arbeiten. Es wurde mit Go entwickelt und kombiniert die Einfachheit von Befehlszeilenschnittstellen mit leistungsstarken Aufgabenverwaltungsfunktionen.

MyTask ToDo CLI Tool...

Warum MyTask?

In einer Welt komplexer Aufgabenverwaltungslösungen zeichnet sich MyTask dadurch aus, dass es sich die Unix-Philosophie zu eigen macht: Eine Sache tun und sie gut machen. Egal, ob Sie codebezogene Aufgaben organisieren, Fehlerbehebungen verwalten oder Funktionen planen, MyTask bietet eine ablenkungsfreie Umgebung, in der Sie produktiv bleiben

Hauptmerkmale

  • Minimal und schnell:In Go geschrieben für außergewöhnliche Leistung und geringen Ressourcenverbrauch
  • Terminal-First: Nahtlose Integration in Ihren bestehenden Terminal-Workflow
  • Befehle im Git-Stil: Vertraute Befehlssyntax für Entwickler (mytask add, mytask list usw.)
  • Plattformübergreifend: Läuft unter Linux, macOS und Windows
  • Datenportabilität:Speichern Sie Ihre Aufgaben in Nur-Text-Dateien und synchronisieren Sie sie problemlos geräteübergreifend
  • Anpassbar: Umfangreiche Konfigurationsmöglichkeiten bei gleichzeitiger Beibehaltung der Einfachheit

Projekteinschränkung:

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

Projekt-Setup

  • Erstellen Sie ein Projektverzeichnis:
mkdir mytask
  • Navigieren Sie zum Verzeichnis:
cd mytask
  • Ein Go-Modul initialisieren:
go mod init github.com/dev-dhanushkumar/golang-projects/mytask
  • SimpleTable-Paket: Simpletable ist eine einfache, leichte Go-Bibliothek zum Erstellen schöner CLI-Tabellen. Es eignet sich besonders gut für unsere Aufgabenverwaltungsanwendung, da es eine saubere, formatierte Ausgabe für Aufgabenlisten liefert.
 go get github.com/alexeyco/simpletable
  • Erstellen Sie Ordner und Dateien basierend auf der Projektstruktur:Diese Dateistruktur bietet eine solide Grundlage für Ihr Projekt.

Durchführung

1. Aufgabe hinzufügen

Hinzufügen einer neuen Aufgabe zu einer Aufgabenliste. Es nutzt das Flag-Paket, um Befehlszeilenargumente zu verarbeiten, und das Todo-Paket (wahrscheinlich an anderer Stelle), um die eigentlichen Todo-Listendaten zu verwalten.

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. Aufgabe löschen

Vorhandene Aufgaben aus der Aufgabenliste löschen. Es verwendet wahrscheinlich das Flag-Paket, um Befehlszeilenargumente zu verarbeiten, und interagiert mit dem ToDo-Paket, um die ToDo-Listendaten zu verwalten.

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. Aufgabe auflisten

Im Kontext einer Befehlszeilen-Aufgabenlistenanwendung wie MyTask bezieht sich der Befehl „list“ normalerweise auf die Aktion, dem Benutzer die aktuelle Liste der Aufgabeneinträge anzuzeigen. Basierend auf der folgenden Beschreibung zeigen wir unsere Aufgabenliste an.

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

4. Aufgabe aktualisieren

Diese Funktion dient zum Aktualisieren einer vorhandenen Aufgabe in der Aufgabenliste und zum Aktualisieren des Aufgabenstatus. Es nutzt das Flag-Paket zur Verarbeitung von Befehlszeilenargumenten und interagiert mit dem Todo-Paket (wahrscheinlich an anderer Stelle), um die eigentlichen Todo-Listendaten zu verwalten.

cd mytask

Installation und Nutzung:

Detaillierte Installations- und Nutzungsanweisungen finden Sie in der Datei README.md im Projekt-Repository: [https://github.com/dev-dhanushkumar/Golang-Projects/tree/main/golang_task]

Abschluss

Dieses Projekt erstellt erfolgreich die Kernfunktionalität der MyTask-Anwendung. Durch diesen Prozess habe ich wertvolle Erfahrungen in der Go-Programmierung, der Entwicklung von Befehlszeilenschnittstellen und dem Projektmanagement gesammelt. Ich habe gelernt, Herausforderungen wie die Implementierung effizienter Aufgabenspeicherung, Dateianalyse und lokaler Speicherung zu meistern und die Go-Standardbibliothek effektiv zu nutzen. Dieses Projekt dient als wertvolle Lernerfahrung und als Grundlage für die weitere Entwicklung im Bereich Aufgabenverwaltungsanwendungen.

Das obige ist der detaillierte Inhalt vonMyTask ToDo CLI-Tool.... Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn