Heim >Backend-Entwicklung >PHP-Tutorial >Drupal: So erstellen Sie Ihren eigenen DRUSH -Befehl

Drupal: So erstellen Sie Ihren eigenen DRUSH -Befehl

William Shakespeare
William ShakespeareOriginal
2025-02-21 10:50:12610Durchsuche

Drupal: How to Create Your Own Drush Command

Schlüsselkonzepte

  • DRUSH-Erweiterbarkeit: DRUSH, Drupal-Befehlszeilenschnittstelle, ermöglicht die Erweiterung der Funktionalität mit benutzerdefinierten Befehlen in Modulen. Dies ermöglicht die Automatisierung spezifischer Drupal -Vorgänge.
  • Befehlsstruktur: Erstellen eines DRUSH -Befehls beinhaltet eine .drush.inc -Datei (in Ihrem Modul), die Funktion hook_drush_command() für die Befehlsdefinition und eine Rückruffunktion, um die Logik des Befehls auszuführen.
  • Argumente und Optionen: Befehle können obligatorische Argumente und optionale Optionen akzeptieren und die Anpassung verbessern. Argumente werden als Funktionsparameter übergeben, während Optionen mit drush_get_option().
  • abgerufen werden
  • Interaktive Eingabe und Verfeinerungen: Befehle können Benutzereingaben anfordern, Verwendungsbeispiele angeben und Abhängigkeiten angeben (Drupal Bootstrap -Ebene, Module, Kernversion).

DRUSH -Stromlinien Drupal Management aus dem Terminal. Beim Angebot von vorgefertigten Befehlen (Modul-Download, Aktivieren, Update) liegt die wahre Leistung beim Erstellen benutzerdefinierter Befehle. Dieses Tutorial zeigt, dass ein DRUSH -Befehl für ein einfaches, illustratives Modul erstellt wird. Der Fokus liegt auf der Befehlsstruktur von DRUSH, nicht auf der Kernfunktionalität des Moduls. Beispielcode ist in [dieses Repository] verfügbar (Repository_Link_here - Ersetzen Sie, falls verfügbar).

.

Unser Beispielmodul

demo_drush Die Funktionalität des Moduls

ist eine grundlegende Funktion:
<code class="language-php">function demo_drush_print_statement() {
  drupal_set_message(t('Hello world!'));
}</code>

Diese Funktion wird verwendet, um zu demonstrieren, wie Drush -Nachrichten zur Konsole gedruckt werden. Wir werden es später ändern, um verschiedene Befehlsfunktionen zu präsentieren.

demo_drush.drush.inc Die DRUSH -Befehlsdatei ()

demo_drush.drush.inc Erstellen Sie .drush.inc im Verzeichnis Ihres Moduls. Drush identifiziert und lädt Funktionen aus Dateien, die in

enden.

Befehlshaken und Rückruf

hook_drush_command() DRUSH -Befehlsarchitektur umfasst zwei Hauptteile: die hook_drush_command() -implementierung (Definieren von Befehlen und Konfigurationen) und Rückruffunktionen, die durch Befehle ausgelöst werden. Beginnen wir mit

:
<code class="language-php">/**
 * Implements hook_drush_command().
 */
function drush_demo_drush_command() {
  $items['drush-demo-command'] = array(
    'description' => 'Demonstrates Drush command functionality.',
    'aliases' => array('ddc'),
  );
  return $items;
}</code>

drush-demo-command Dies definiert einen Befehl namens ddc (aliased als drush_drush_demo_command()). Die Rückruffunktion (standardmäßig

) führt die Logik des Befehls aus:
<code class="language-php">/**
 * Callback for the drush-demo-command command.
 */
function drush_drush_demo_command() {
  demo_drush_print_statement();
}</code>

drush cc drush Nach dem Löschen des DRUSH -Cache (drush ddc) und ausgeführt

Drucke "Hallo Welt!" zur Konsole.

Argumente und Optionen

Verbessern Sie Ihren Befehl mit Argumenten (obligatorisch) und Optionen (optional). Fügen wir sie zum Haken hinzu:
<code class="language-php">function demo_drush_print_statement() {
  drupal_set_message(t('Hello world!'));
}</code>

Now, drush ddc error --repeat=10 legt den Anweisungsart auf "Fehler" fest und wiederholt ihn 10 Mal. Aktualisieren Sie demo_drush_print_statement() und die Rückruffunktion entsprechend:

<code class="language-php">/**
 * Implements hook_drush_command().
 */
function drush_demo_drush_command() {
  $items['drush-demo-command'] = array(
    'description' => 'Demonstrates Drush command functionality.',
    'aliases' => array('ddc'),
  );
  return $items;
}</code>

Benutzereingabe

Fehlende Argumente interaktiv verarbeiten:

<code class="language-php">/**
 * Callback for the drush-demo-command command.
 */
function drush_drush_demo_command() {
  demo_drush_print_statement();
}</code>

Beispiele in hook_drush_command()

Beispiele zum Haken hinzufügen:

<code class="language-php">...
'arguments' => array(
  'type' => 'Statement type (error or success).',
),
'options' => array(
  'repeat' => 'Number of statement repeats.',
),
...</code>

Schlussfolgerung

Dieses Tutorial deckt die Grundlagen des Erstellens von DRUSH -Befehlen ab. Erforschen Sie erweiterte Funktionen wie Bootstrap -Ebenen, Modulabhängigkeiten und Kompatibilität der Kernversion in der Dokumentation der DRUSH -API.

häufig gestellte Fragen (FAQs) (diese sind bereits in der Eingabe gut geschrieben, sie müssen sie nicht neu schreiben)

Das obige ist der detaillierte Inhalt vonDrupal: So erstellen Sie Ihren eigenen DRUSH -Befehl. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn