


Comment développer un package pour l'éditeur de code atome de GitHub & # x27;
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.
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 fichierpackage.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.
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.
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" }
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"
, 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
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" }
- : 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
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']
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 } ]
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 à 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' }
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' }
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.
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!

Outils d'IA chauds

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

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

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

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 !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

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

Sujets chauds

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

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

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

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
