Maison > développement back-end > Golang > Outil CLI MyTask ToDo...

Outil CLI MyTask ToDo...

DDD
Libérer: 2024-12-25 15:54:14
original
456 Les gens l'ont consulté

Introduction

MyTask est une application de gestion de tâches moderne et légère conçue pour les développeurs qui préfèrent travailler dans un environnement de terminal. Construit avec Go, il combine la simplicité des interfaces de ligne de commande avec de puissantes fonctionnalités de gestion des tâches.

MyTask ToDo CLI Tool...

Pourquoi MyTask ?

Dans un monde de solutions de gestion de tâches complexes, MyTask se démarque en adoptant la philosophie Unix : faites une chose et faites-la bien. Que vous organisiez des tâches liées au code, gériez des corrections de bugs ou planifiiez des fonctionnalités, MyTask fournit un environnement sans distraction pour rester productif

Principales fonctionnalités

  • Minimal et rapide : Écrit en Go pour des performances exceptionnelles et une faible utilisation des ressources
  • Terminal-First : Intégration transparente avec votre flux de travail de terminal existant
  • Commandes de style Git :Syntaxe de commande familière pour les développeurs (mytask add, mytask list, etc.)
  • Multiplateforme : Fonctionne sous Linux, macOS et Windows
  • Portabilité des données : Stockez vos tâches dans des fichiers en texte brut, synchronisez facilement entre les appareils
  • Personnalisable : Options de configuration étendues tout en conservant la simplicité

Strictement du projet :

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
Copier après la connexion
Copier après la connexion

Configuration du projet

  • Créer un répertoire de projets :
mkdir mytask
Copier après la connexion
Copier après la connexion
  • Accédez au répertoire :
cd mytask
Copier après la connexion
Copier après la connexion
  • Initialiser un module Go :
go mod init github.com/dev-dhanushkumar/golang-projects/mytask
Copier après la connexion
  • Forfait SimpleTable : Simpletable est une bibliothèque Go simple et légère permettant de créer de superbes tables CLI. Il est particulièrement adapté à notre application de gestion de tâches car il fournit une sortie propre et formatée pour les listes de tâches.
 go get github.com/alexeyco/simpletable
Copier après la connexion
  • Créez des dossiers et des fichiers basés sur la structure du projet : Cette structure de fichiers fournit une base solide pour votre projet.

Mise en œuvre

1. Ajouter une tâche

Ajout d'une nouvelle tâche à une liste de tâches. Il utilise le package flag pour gérer les arguments de ligne de commande et le package todo (probablement situé ailleurs) pour gérer les données réelles de la liste de tâches.

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.")
}
Copier après la connexion

2. Supprimer la tâche

Suppression des tâches existantes de la liste de tâches. Il utilise probablement le package flag pour gérer les arguments de ligne de commande et interagit avec le package todo pour gérer les données de la liste de tâches.

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.")
}
Copier après la connexion

3. Liste des tâches

Dans le contexte d'une application de liste de tâches en ligne de commande telle que MyTask, la commande "list" fait généralement référence à l'action d'afficher la liste actuelle des éléments de tâche à l'utilisateur. Sur la base de la description ci-dessous, nous affichons notre liste de tâches.

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
Copier après la connexion
Copier après la connexion
  • Exemple :
mkdir mytask
Copier après la connexion
Copier après la connexion

4. Tâche de mise à jour

Cette fonctionnalité permet de mettre à jour une tâche existante dans la liste de tâches et de mettre à jour l'état de la tâche. Il utilise le package flag pour gérer les arguments de ligne de commande et interagit avec le package todo (probablement situé ailleurs) pour gérer les données réelles de la liste de tâches.

cd mytask
Copier après la connexion
Copier après la connexion

Installation et utilisation :

Pour des instructions détaillées d'installation et d'utilisation, veuillez vous référer au fichier README.md dans le référentiel du projet : [https://github.com/dev-dhanushkumar/Golang-Projects/tree/main/golang_task]

Conclusion

Ce projet crée avec succès la fonctionnalité de base de l'application MyTask. Grâce à ce processus, j'ai acquis une expérience précieuse en programmation Go, développement d'interfaces de ligne de commande et gestion de projet. J'ai appris à surmonter des défis tels que la mise en œuvre d'un stockage de tâches efficace, l'analyse de fichiers, le stockage local et à utiliser efficacement la bibliothèque standard Go. Ce projet constitue une expérience d'apprentissage précieuse et une base pour un développement ultérieur dans le domaine des applications de gestion de tâches.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:dev.to
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal