Maison >interface Web >js tutoriel >Utilisez degit pour télécharger un modèle dans votre outil CLI.
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 :
Je me souviens avoir vu "degit" mentionné dans l'un des 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, donc ce n'est pas limité 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'); });
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.
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';
export function fetch(url: string, dest: string) { return new Promise<void>((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); }); }
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, }, [], ); }
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.
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 dans le package create-video pour preuve.
Obtenez des cours gratuits inspirés des meilleures pratiques utilisées en open source.
Site Internet : https://ramunarasinga.com/
Linkedin : https://www.linkedin.com/in/ramu-narasinga-189361128/
Github : https://github.com/Ramu-Narasinga
Email : ramu.narasinga@gmail.com
Découvrez les meilleures pratiques utilisées en open source.
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!