"Si un ouvrier veut bien faire son travail, il doit d'abord affûter ses outils." - Confucius, "Les Entretiens de Confucius. Lu Linggong"
Page de garde > La programmation > Utilisez degit pour télécharger un modèle dans votre outil CLI.

Utilisez degit pour télécharger un modèle dans votre outil CLI.

Publié le 2024-11-02
Parcourir:779

J'ai trouvé un fichier nommé "degit" dans le code source de Remotion.
Remotion vous aide à créer des vidéos par programmation.

Dans cet article, nous examinerons les concepts suivants :

  1. Qu'est-ce que Degit ?
  2. Créez une fonction degit simple inspirée du fichier degit de Remotion

Qu’est-ce que le Degit ?

Je me souviens avoir vu "degit" mentionné dans l'un des fichiers Readmes de l'open source, mais je ne me souvenais pas de quel référentiel il s'agissait, alors j'ai cherché sur Google ce que signifie un degit et j'ai trouvé ce package npm degit.

En termes simples, vous pouvez utiliser degit pour faire rapidement une copie d'un référentiel Github en téléchargeant uniquement le dernier commit
au lieu de l'intégralité de l'historique de git.

Visitez le package npm officiel pour degit pour en savoir plus sur ce package.

Vous pouvez également utiliser ce package degit pour télécharger des dépôts depuis Gitlab ou Bitbucket, il ne se limite donc pas uniquement aux référentiels Github.

# download from GitLab
degit gitlab:user/repo

# download from BitBucket
degit bitbucket:user/repo

degit user/repo
# these commands are equivalent
degit github:user/repo

Voici un exemple d'utilisation en Javascript :

const degit = require('degit');

const emitter = degit('user/repo', {
    cache: true,
    force: true,
    verbose: true,
});

emitter.on('info', info => {
    console.log(info.message);
});

emitter.clone('path/to/dest').then(() => {
    console.log('done');
});

Créez une fonction degit simple inspirée du fichier degit de Remotion

Pour comprendre comment créer une fonction degit simple, décomposons le code du fichier degit.ts de Remotion. Ce fichier implémente une version de base de ce que fait le package degit npm : récupérer le dernier état d'un référentiel GitHub sans télécharger l'historique complet.

1. Importations utilisées

import https from 'https';
import fs from 'node:fs';
import {tmpdir} from 'node:os';
import path from 'node:path';
import tar from 'tar';
import {mkdirp} from './mkdirp';
  • https : utilisé pour effectuer une requête réseau pour récupérer le référentiel.
  • fs : interagit avec le système de fichiers, par exemple en écrivant les fichiers téléchargés.
  • tmpdir : fournit le chemin du répertoire temporaire du système.
  • path : gère et transforme les chemins d'accès aux fichiers.
  • tar : extrait le contenu de l'archive tar (fichier compressé).
  • mkdirp : une fonction d'assistance pour créer des répertoires de manière récursive, fournie dans un fichier séparé.

2 : Récupérer le référentiel

export function fetch(url: string, dest: string) {
    return new Promise((resolve, reject) => {
        https.get(url, (response) => {
            const code = response.statusCode as number;
            if (code >= 400) {
                reject(
                    new Error(
                        `Network request to ${url} failed with code ${code} (${response.statusMessage})`,
                    ),
                );
            } else if (code >= 300) {
                fetch(response.headers.location as string, dest)
                    .then(resolve)
                    .catch(reject);
            } else {
                response
                    .pipe(fs.createWriteStream(dest))
                    .on('finish', () => resolve())
                    .on('error', reject);
            }
        }).on('error', reject);
    });
}
  • Gestion des URL : la fonction vérifie si la demande aboutit (codes d'état inférieurs à 300). S'il s'agit d'une redirection (codes entre 300 et 399), elle suit la nouvelle URL. S'il s'agit d'une erreur (codes 400 ), il rejette la promesse.
  • Enregistrement de fichier : le référentiel est téléchargé et enregistré dans le chemin de destination à l'aide de fs.createWriteStream.

3 : Extraction du référentiel

Après avoir téléchargé le référentiel, il est nécessaire d'extraire le contenu de l'archive tar :

function untar(file: string, dest: string) {
    return tar.extract(
        {
            file,
            strip: 1,
            C: dest,
        },
        [],
    );
}
  • Extraction Tar : cette fonction extrait le contenu du fichier .tar.gz dans le répertoire de destination spécifié.

4 : Mettre tout cela ensemble

La fonction principale degit relie tout ensemble, gérant la création de répertoires, la récupération et l'extraction du référentiel :

export const degit = async ({
    repoOrg,
    repoName,
    dest,
}: {
    repoOrg: string;
    repoName: string;
    dest: string;
}) => {
    const base = path.join(tmpdir(), '.degit');
    const dir = path.join(base, repoOrg, repoName);
    const file = `${dir}/HEAD.tar.gz`;
    const url = `https://github.com/${repoOrg}/${repoName}/archive/HEAD.tar.gz`;

    mkdirp(path.dirname(file));
    await fetch(url, file);

    mkdirp(dest);
    await untar(file, dest);
    fs.unlinkSync(file);
};

mkdirp est utilisé pour créer
un répertoire de manière récursive.

Conclusion:

J'ai découvert que Remotion utilise Degit pour télécharger des modèles lorsque vous exécutez leur commande d'installation :

npx create-video@latest

Cette commande vous demande de choisir un modèle, c'est là que degit entre en action pour télécharger
le dernier commit du modèle sélectionné

Vous pouvez vérifier ce code à partir du package create-video pour preuve.

Use degit to download a template in your CLI tool.

Obtenez des cours gratuits inspirés des meilleures pratiques utilisées dans l'open source.

Sur moi:

Site Web : https://ramunarasinga.com/

Linkedin : https://www.linkedin.com/in/ramu-narasinga-189361128/

Github : https://github.com/Ramu-Narasinga

E-mail : [email protected]

Découvrez les meilleures pratiques utilisées dans l'open source.

Références :

  1. https://github.com/Rich-Harris/degit
  2. https://github.com/remotion-dev/remotion/blob/main/packages/create-video/src/degit.ts
  3. https://github.com/remotion-dev/remotion/blob/c535e676badd055187d1ea8007f9ac76ab0ad315/packages/create-video/src/init.ts#L109
  4. https://github.com/remotion-dev/remotion/blob/main/packages/create-video/src/mkdirp.ts
Déclaration de sortie Cet article est reproduit sur : https://dev.to/ramunarasinga/use-degit-to-download-a-template-in-your-cli-tool-6hg?1 En cas de violation, veuillez contacter study_golang@163 .com pour le supprimer
Dernier tutoriel Plus>

Clause de non-responsabilité: Toutes les ressources fournies proviennent en partie d'Internet. En cas de violation de vos droits d'auteur ou d'autres droits et intérêts, veuillez expliquer les raisons détaillées et fournir une preuve du droit d'auteur ou des droits et intérêts, puis l'envoyer à l'adresse e-mail : [email protected]. Nous nous en occuperons pour vous dans les plus brefs délais.

Copyright© 2022 湘ICP备2022001581号-3