Table des matières
avec begin et end
Maison Périphériques technologiques Industrie informatique Comment développer un package pour l'éditeur de code atome de GitHub & # x27;

Comment développer un package pour l'éditeur de code atome de GitHub & # x27;

Feb 19, 2025 am 10:20 AM

Guide d'extension de l'éditeur ATOM: Créez et publiez votre propre package de surligneur de syntaxe

L'éditeur atomique est puissant, mais parfois vous pouvez avoir besoin de certaines fonctionnalités qui ne sont pas fournies par défaut, telles que la syntaxe mettant en évidence pour une langue spécifique. Pour le moment, il est particulièrement important de créer des packages personnalisés. Cet article vous guidera pour créer un package de mise en évidence de syntaxe et le publiera dans la communauté Atom.

How To Develop a Package for GitHub's Atom Code Editor

Points de base:

  • Étendez la fonctionnalité de l'éditeur d'atomes en créant des packages personnalisés, en particulier pour les fonctionnalités qui manquent par défaut.
  • Créez un dossier dans le répertoire .atom/packages et ajoutez un fichier package.json valide pour initialiser le nouveau package.
  • Pour la mise en évidence de la syntaxe, créez un sous-dossier grammars, définissez les règles linguistiques dans un fichier CSON et spécifiez comment Atom reconnaît et met en évidence la syntaxe linguistique.
  • Testez votre package dans l'atome à l'aide de la fonction View/Reload pour afficher immédiatement les modifications et assurez-vous que la fonctionnalité fonctionne.
  • Configurez un référentiel public sur GitHub et utilisez la commande apm publish pour publier votre package dans la communauté Atom au profit d'autres développeurs.

Que allons-nous construire?

Cet article vous guidera pour créer un surligneur de syntaxe similaire à language-scilab que vous pouvez appliquer à n'importe quelle langue dont vous avez besoin. Nous apprendrons à initialiser un nouveau package, à écrire des règles de mise en évidence de la syntaxe et à publier votre package dans la communauté Atom.

Initialisez le nouveau package d'atomes

Atom utilise un dossier de fichiers de configuration appelé .atom pour stocker des options personnelles et des packages installés. Les packages sont situés dans le sous-dossier packages de ce dossier, et chaque package a son propre dossier.

How To Develop a Package for GitHub's Atom Code Editor

La première étape consiste à créer votre dossier de package, tel que language-mylanguage (il s'agit d'une convention de dénomination pour ajouter le support linguistique). Ensuite, créez le fichier package.json dans ce dossier, et l'atome peut le reconnaître et le charger.

How To Develop a Package for GitHub's Atom Code Editor

Ce qui suit est un exemple du fichier language-mylanguage d'un package package.json:

{
  "name": "language-mylanguage",
  "version": "0.0.0",
  "description": "Mylanguage language support in Atom",
  "engines": {
    "atom": "*"
  },
  "dependencies": {},
  "repository": {
    "type": "git",
    "url": "https://github.com/JeremyHeleine/language-mylanguage.git"
  },
  "bugs": {
    "url": "https://github.com/JeremyHeleine/language-mylanguage/issues"
  },
  "license": "MIT"
}
Copier après la connexion
Copier après la connexion

Keyfield Explication:

  • "name": Nom du package.
  • "version": Numéro de version, suivant la convention pour les versions majeures, mineures et révisées. 0.0.0
  • : Description du package. "description"
  • : Exigences de version minimale de l'atome. "engines"
  • : dépendances de package. "dependencies"
  • : L'adresse du référentiel GitHub du package (peut être vide avant la libération). "repository"
  • : Adresse pour signaler le problème. "bugs"
  • : Licence. "license"
Après avoir créé le fichier

, Atom peut reconnaître votre package. Vous pouvez utiliser la commande package.json pour forcer l'atome à recharger le package afin que les modifications soient immédiatement visibles. View/Reload

Créez un package de surligneur de syntaxe

Créez un sous-dossier

dans le dossier Package et créez un fichier CSON nommé d'après le nom de la langue (par exemple grammars). Ce fichier contient des règles de mise en évidence de syntaxe. mylanguage.cson

Informations de base

Avant de définir les règles de grammaire, vous devez dire à Atom comment reconnaître votre langue:

{
  "name": "language-mylanguage",
  "version": "0.0.0",
  "description": "Mylanguage language support in Atom",
  "engines": {
    "atom": "*"
  },
  "dependencies": {},
  "repository": {
    "type": "git",
    "url": "https://github.com/JeremyHeleine/language-mylanguage.git"
  },
  "bugs": {
    "url": "https://github.com/JeremyHeleine/language-mylanguage/issues"
  },
  "license": "MIT"
}
Copier après la connexion
Copier après la connexion
  • : identifiant de langue, utilisé pour des sujets, d'autres packages ou des fichiers de configuration. scopeName
  • : Le nom de la langue affichée en bas de l'éditeur Atom. name
  • : le tableau d'extension de fichier utilisé par la langue. fileTypes
Règles de grammaire

Toutes les règles doivent être déclarées dans le tableau

, chaque règle est enfermée dans patterns: {}

'scopeName': 'source.mylanguage'
'name': 'Mylanguage'
'fileTypes': ['ext1', 'ext2']
Copier après la connexion
Faire correspondre les éléments de syntaxe

Faire correspondre les éléments de syntaxe à l'aide de l'attribut

, tels que les numéros de correspondance: match

'scopeName': 'source.mylanguage'
'name': 'Mylanguage'
'fileTypes': ['ext1', 'ext2']

'patterns': [
    {
        # 规则1
    },
    {
        # 规则2
    }
]
Copier après la connexion

Utilisez des expressions régulières, match Spécifiez le nom de la classe de style et suivez certaines conventions de dénomination afin que le thème puisse appliquer correctement le style. name

Faire correspondre plusieurs éléments

Faire correspondre plusieurs éléments à l'aide de l'attribut

, tels que la déclaration de fonction de correspondance: captures

{
    'match': '\b(([0-9]+\.?[0-9]*)|(\.[0-9]+))\b'
    'name': 'constant.numeric.mylanguage'
}
Copier après la connexion
Match

avec begin et end

Faites correspondre les balises de début et de fin à l'aide des propriétés begin et end, telles que la correspondance des chaînes de devis unique:

{
    'match': '\b(function)\s+(\w+)\s*\(.*\)'
    'captures': {
        '1': { 'name': 'keyword.control.mylanguage' },
        '2': { 'name': 'entity.name.function.mylanguage' }
    },
    'name': 'meta.function.mylanguage'
}
Copier après la connexion

Vous pouvez également utiliser beginCaptures et endCaptures pour capturer les balises de début et de fin, et les attributs patterns correspondent aux sous-éléments à l'intérieur de l'élément correspondant.

Libérer le package d'atomes

Veuillez vérifier si le package avec le même nom existe déjà avant de le publier. Vous avez besoin d'un référentiel GitHub public. Mettez à jour l'adresse du référentiel dans le fichier package.json.

Utilisez la commande apm publish minor pour publier respectivement le package (minor, major, et patch, mettent respectivement à mettre à jour la version mineure, la version majeure et la version de correction). Cette commande enregistrera le nom de votre package, ajoutera le numéro de version, créera des balises GIT et pousse les modifications.

How To Develop a Package for GitHub's Atom Code Editor

Utilisez la commande apm unpublish name-of-the-package pour annuler le package de version.

Conclusion

Cet article décrit comment créer et publier des packages de mise en évidence de la syntaxe des atomes. La flexibilité de l'ATOM permet la création de différents types de packages, mais cet article est limité à la création de packages en surbrillance syntaxes. J'espère que cet article vous aidera à élargir la fonctionnalité de l'éditeur d'ATOM et à partager vos résultats avec la communauté.

FAQS (FAQ)

(La partie FAQ dans le texte d'origine est omise ici, car le contenu de cette partie est très répétitif par rapport à ce qui précède, qui est un résumé et une explication du contenu ci-dessus. Afin d'éviter la redondance, la sortie répétée n'est pas effectuée ici.)

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 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

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

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Construire un scanner de vulnérabilité de réseau avec Go Construire un scanner de vulnérabilité de réseau avec Go Apr 01, 2025 am 08:27 AM

Ce scanner de vulnérabilité de réseau basé sur GO identifie efficacement les faiblesses de sécurité potentielles. Il exploite les fonctionnalités de concurrence de GO pour la vitesse et comprend la détection de services et la correspondance de vulnérabilité. Explorons ses capacités et ses éthiques

Pilote CNCF ARM64: impact et perspectives Pilote CNCF ARM64: impact et perspectives Apr 15, 2025 am 08:27 AM

Ce programme pilote, une collaboration entre le CNCF (Cloud Native Computing Foundation), Ampere Computing, Equinix Metal et ACTUTIE, rationalise ARM64 CI / CD pour les projets GitHub CNCF. L'initiative répond aux problèmes de sécurité et aux performances LIM

Pipeline de traitement d'image sans serveur avec AWS ECS et Lambda Pipeline de traitement d'image sans serveur avec AWS ECS et Lambda Apr 18, 2025 am 08:28 AM

Ce tutoriel vous guide dans la création d'un pipeline de traitement d'image sans serveur à l'aide de services AWS. Nous allons créer un frontend Next.js déployé sur un cluster ECS Fargate, en interagissant avec une passerelle API, des fonctions lambda, des seaux S3 et DynamoDB. Ème

Top 21 newsletters du développeur auquel s'abonner en 2025 Top 21 newsletters du développeur auquel s'abonner en 2025 Apr 24, 2025 am 08:28 AM

Restez informé des dernières tendances technologiques avec ces meilleurs bulletins de développeur! Cette liste organisée offre quelque chose pour tout le monde, des amateurs d'IA aux développeurs assaisonnés du backend et du frontend. Choisissez vos favoris et gagnez du temps à la recherche de rel

See all articles