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

Drupal: So erstellen Sie Ihren eigenen DRUSH -Befehl

William Shakespeare
Freigeben: 2025-02-21 10:50:12
Original
606 Leute haben es durchsucht

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:
function demo_drush_print_statement() {
  drupal_set_message(t('Hello world!'));
}
Nach dem Login kopieren
Nach dem Login kopieren

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

:
/**
 * Implements hook_drush_command().
 */
function drush_demo_drush_command() {
  $items['drush-demo-command'] = array(
    'description' => 'Demonstrates Drush command functionality.',
    'aliases' => array('ddc'),
  );
  return $items;
}
Nach dem Login kopieren
Nach dem Login kopieren

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:
/**
 * Callback for the drush-demo-command command.
 */
function drush_drush_demo_command() {
  demo_drush_print_statement();
}
Nach dem Login kopieren
Nach dem Login kopieren

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: <🎜>
function demo_drush_print_statement() {
  drupal_set_message(t('Hello world!'));
}
Nach dem Login kopieren
Nach dem Login kopieren

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:

/**
 * Implements hook_drush_command().
 */
function drush_demo_drush_command() {
  $items['drush-demo-command'] = array(
    'description' => 'Demonstrates Drush command functionality.',
    'aliases' => array('ddc'),
  );
  return $items;
}
Nach dem Login kopieren
Nach dem Login kopieren

Benutzereingabe

Fehlende Argumente interaktiv verarbeiten:

/**
 * Callback for the drush-demo-command command.
 */
function drush_drush_demo_command() {
  demo_drush_print_statement();
}
Nach dem Login kopieren
Nach dem Login kopieren

Beispiele in hook_drush_command()

Beispiele zum Haken hinzufügen:

...
'arguments' => array(
  'type' => 'Statement type (error or success).',
),
'options' => array(
  'repeat' => 'Number of statement repeats.',
),
...
Nach dem Login kopieren

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!

Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage