recherche
Maisondéveloppement back-endGolangOutil CLI MyTask ToDo...

Outil CLI MyTask ToDo...

Dec 25, 2024 pm 03:54 PM

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

Configuration du projet

  • Créer un répertoire de projets :
mkdir mytask
  • Accédez au répertoire :
cd mytask
  • Initialiser un module Go :
go mod init github.com/dev-dhanushkumar/golang-projects/mytask
  • 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
  • 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.")
}

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.")
}

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

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

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!

Déclaration
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
Construire des systèmes évolutifs avec le langage de programmation GoConstruire des systèmes évolutifs avec le langage de programmation GoApr 25, 2025 am 12:19 AM

GOISIDEALFORBUILDingsCalableSystemsDuetOtssimplicity, Efficiency et Build-InconcurrencySupport.1) Go'scleanSyntaxandMinImaliticDesignenHance Produductivity andreduceerrors.2)

Meilleures pratiques pour utiliser efficacement les fonctions d'initiés dans GoMeilleures pratiques pour utiliser efficacement les fonctions d'initiés dans GoApr 25, 2025 am 12:18 AM

InitFunctionSingorunAutomAtical BeforEmain () etaareusefulforsttingUnvironments etInitializingVaribles.Usethemforsimpletasks, évitez les effets et les plus compatibles avec un test de règlement.

L'ordre d'exécution des fonctions d'initiés dans les packages GOL'ordre d'exécution des fonctions d'initiés dans les packages GOApr 25, 2025 am 12:14 AM

GOINITIALISESPACKAGSEURSETHEORDETHEYARE IMPORTÉ, ENTERNEXECUTES INSIMITÉSEMENTSWithInapackageIntheirdFinitionOrder, et les nom

Définir et utiliser des interfaces personnalisées dans GODéfinir et utiliser des interfaces personnalisées dans GOApr 25, 2025 am 12:09 AM

Custom InterfaceSingoArecrucialforwritingFlexible, maintenable, andtablecode.

Utilisation d'interfaces pour se moquer et tester en GoUtilisation d'interfaces pour se moquer et tester en GoApr 25, 2025 am 12:07 AM

La raison de l'utilisation d'interfaces pour la simulation et les tests est que l'interface permet la définition de contrats sans spécifier les implémentations, ce qui rend les tests plus isolés et faciles à maintenir. 1) L'implémentation implicite de l'interface permet de créer des objets simulés, qui peuvent remplacer les implémentations réelles dans les tests. 2) L'utilisation d'interfaces peut facilement remplacer la mise en œuvre réelle du service dans les tests unitaires, en réduisant la complexité et le temps des tests. 3) La flexibilité fournie par l'interface permet des modifications du comportement simulé pour différents cas de test. 4) Les interfaces aident à concevoir le code testable depuis le début, améliorant la modularité et la maintenabilité du code.

Utilisation de l'initialisation init pour l'initialisation du package en GoUtilisation de l'initialisation init pour l'initialisation du package en GoApr 24, 2025 pm 06:25 PM

Dans GO, la fonction INIT est utilisée pour l'initialisation du package. 1) La fonction INIT est automatiquement appelée lors de l'initialisation du package et convient pour initialiser les variables globales, définir les connexions et charger des fichiers de configuration. 2) Il peut y avoir plusieurs fonctions d'initiation qui peuvent être exécutées dans l'ordre des fichiers. 3) Lorsque vous l'utilisez, l'ordre d'exécution, la difficulté de test et l'impact des performances doivent être pris en compte. 4) Il est recommandé de réduire les effets secondaires, d'utiliser l'injection de dépendance et l'initialisation de retard pour optimiser l'utilisation des fonctions d'initié.

Énoncé de sélection de Go: Multiplexage des opérations simultanéesÉnoncé de sélection de Go: Multiplexage des opérations simultanéesApr 24, 2025 pm 05:21 PM

Go'SelectStatementsTreamlinesConcurrentProgrammingyMultiplexingOperations.1)

Techniques de concurrence avancées en Go: contexte et groupes d'attenteTechniques de concurrence avancées en Go: contexte et groupes d'attenteApr 24, 2025 pm 05:09 PM

ContextandWaitGroupSaRucialialingOgormaninggoroutinesesectively.1) ContextAllowssignalingcancellation andDeadlinesAcrossapiboundaries, assurant que vous êtes en train de vous assurer

See all articles

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Listes Sec

Listes Sec

SecLists est le compagnon ultime du testeur de sécurité. Il s'agit d'une collection de différents types de listes fréquemment utilisées lors des évaluations de sécurité, le tout en un seul endroit. SecLists contribue à rendre les tests de sécurité plus efficaces et productifs en fournissant facilement toutes les listes dont un testeur de sécurité pourrait avoir besoin. Les types de listes incluent les noms d'utilisateur, les mots de passe, les URL, les charges utiles floues, les modèles de données sensibles, les shells Web, etc. Le testeur peut simplement extraire ce référentiel sur une nouvelle machine de test et il aura accès à tous les types de listes dont il a besoin.

mPDF

mPDF

mPDF est une bibliothèque PHP qui peut générer des fichiers PDF à partir de HTML encodé en UTF-8. L'auteur original, Ian Back, a écrit mPDF pour générer des fichiers PDF « à la volée » depuis son site Web et gérer différentes langues. Il est plus lent et produit des fichiers plus volumineux lors de l'utilisation de polices Unicode que les scripts originaux comme HTML2FPDF, mais prend en charge les styles CSS, etc. et présente de nombreuses améliorations. Prend en charge presque toutes les langues, y compris RTL (arabe et hébreu) ​​et CJK (chinois, japonais et coréen). Prend en charge les éléments imbriqués au niveau du bloc (tels que P, DIV),

SublimeText3 Linux nouvelle version

SublimeText3 Linux nouvelle version

Dernière version de SublimeText3 Linux

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

DVWA

DVWA

Damn Vulnerable Web App (DVWA) est une application Web PHP/MySQL très vulnérable. Ses principaux objectifs sont d'aider les professionnels de la sécurité à tester leurs compétences et leurs outils dans un environnement juridique, d'aider les développeurs Web à mieux comprendre le processus de sécurisation des applications Web et d'aider les enseignants/étudiants à enseigner/apprendre dans un environnement de classe. Application Web sécurité. L'objectif de DVWA est de mettre en pratique certaines des vulnérabilités Web les plus courantes via une interface simple et directe, avec différents degrés de difficulté. Veuillez noter que ce logiciel