mirror of
https://fast.feibisi.com/https://github.com/wp-cli/scaffold-command.git
synced 2025-10-04 17:01:28 +08:00
Merge branch 'master' into cron
This commit is contained in:
commit
dadb2ad204
3 changed files with 156 additions and 1 deletions
|
@ -1,4 +1,4 @@
|
|||
Feature: Wordpress code scaffolding
|
||||
Feature: WordPress code scaffolding
|
||||
|
||||
Background:
|
||||
Given a WP install
|
||||
|
@ -72,3 +72,12 @@ Feature: Wordpress code scaffolding
|
|||
"""
|
||||
__( 'Brain eaters'
|
||||
"""
|
||||
|
||||
Scenario: Scaffold a plugin
|
||||
Given I run `wp plugin path`
|
||||
And save STDOUT as {PLUGIN_DIR}
|
||||
|
||||
When I run `wp scaffold plugin hello-world`
|
||||
Then STDOUT should not be empty
|
||||
And the {PLUGIN_DIR}/hello-world/hello-world.php file should exist
|
||||
And the {PLUGIN_DIR}/hello-world/readme.txt file should exist
|
|
@ -212,6 +212,8 @@ class Scaffold_Command extends WP_CLI_Command {
|
|||
WP_CLI::error( "Couldn't create theme (received $response_code response)." );
|
||||
}
|
||||
|
||||
$this->maybe_create_themes_dir();
|
||||
|
||||
unzip_file( $tmpfname, $theme_path );
|
||||
unlink( $tmpfname );
|
||||
|
||||
|
@ -265,6 +267,8 @@ class Scaffold_Command extends WP_CLI_Command {
|
|||
$theme_dir = WP_CONTENT_DIR . "/themes" . "/$theme_slug";
|
||||
$theme_style_path = "$theme_dir/style.css";
|
||||
|
||||
$this->maybe_create_themes_dir();
|
||||
|
||||
$this->create_file( $theme_style_path, Utils\mustache_render( 'child_theme.mustache', $data ) );
|
||||
|
||||
WP_CLI::success( "Created $theme_dir" );
|
||||
|
@ -323,8 +327,12 @@ class Scaffold_Command extends WP_CLI_Command {
|
|||
|
||||
$plugin_dir = WP_PLUGIN_DIR . "/$plugin_slug";
|
||||
$plugin_path = "$plugin_dir/$plugin_slug.php";
|
||||
$plugin_readme_path = "$plugin_dir/readme.txt";
|
||||
|
||||
$this->maybe_create_plugins_dir();
|
||||
|
||||
$this->create_file( $plugin_path, Utils\mustache_render( 'plugin.mustache', $data ) );
|
||||
$this->create_file( $plugin_readme_path, Utils\mustache_render( 'plugin-readme.mustache', $data ) );
|
||||
|
||||
WP_CLI::success( "Created $plugin_dir" );
|
||||
|
||||
|
@ -491,6 +499,30 @@ class Scaffold_Command extends WP_CLI_Command {
|
|||
protected function quote_comma_list_elements( $comma_list ) {
|
||||
return "'" . implode( "', '", explode( ',', $comma_list ) ) . "'";
|
||||
}
|
||||
|
||||
/**
|
||||
* Create the themes directory if it doesn't already exist
|
||||
*/
|
||||
protected function maybe_create_themes_dir() {
|
||||
|
||||
$themes_dir = WP_CONTENT_DIR . '/themes';
|
||||
if ( ! is_dir( $themes_dir ) ) {
|
||||
wp_mkdir_p( $themes_dir );
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Create the plugins directory if it doesn't already exist
|
||||
*/
|
||||
protected function maybe_create_plugins_dir() {
|
||||
|
||||
if ( ! is_dir( WP_PLUGIN_DIR ) ) {
|
||||
wp_mkdir_p( WP_PLUGIN_DIR );
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
WP_CLI::add_command( 'scaffold', 'Scaffold_Command' );
|
||||
|
|
114
templates/plugin-readme.mustache
Normal file
114
templates/plugin-readme.mustache
Normal file
|
@ -0,0 +1,114 @@
|
|||
=== {{plugin_name}} ===
|
||||
Contributors: (this should be a list of wordpress.org userid's)
|
||||
Donate link: http://example.com/
|
||||
Tags: comments, spam
|
||||
Requires at least: 3.0.1
|
||||
Tested up to: 3.4
|
||||
Stable tag: 4.3
|
||||
License: GPLv2 or later
|
||||
License URI: http://www.gnu.org/licenses/gpl-2.0.html
|
||||
|
||||
Here is a short description of the plugin. This should be no more than 150 characters. No markup here.
|
||||
|
||||
== Description ==
|
||||
|
||||
This is the long description. No limit, and you can use Markdown (as well as in the following sections).
|
||||
|
||||
For backwards compatibility, if this section is missing, the full length of the short description will be used, and
|
||||
Markdown parsed.
|
||||
|
||||
A few notes about the sections above:
|
||||
|
||||
* "Contributors" is a comma separated list of wp.org/wp-plugins.org usernames
|
||||
* "Tags" is a comma separated list of tags that apply to the plugin
|
||||
* "Requires at least" is the lowest version that the plugin will work on
|
||||
* "Tested up to" is the highest version that you've *successfully used to test the plugin*. Note that it might work on
|
||||
higher versions... this is just the highest one you've verified.
|
||||
* Stable tag should indicate the Subversion "tag" of the latest stable version, or "trunk," if you use `/trunk/` for
|
||||
stable.
|
||||
|
||||
Note that the `readme.txt` of the stable tag is the one that is considered the defining one for the plugin, so
|
||||
if the `/trunk/readme.txt` file says that the stable tag is `4.3`, then it is `/tags/4.3/readme.txt` that'll be used
|
||||
for displaying information about the plugin. In this situation, the only thing considered from the trunk `readme.txt`
|
||||
is the stable tag pointer. Thus, if you develop in trunk, you can update the trunk `readme.txt` to reflect changes in
|
||||
your in-development version, without having that information incorrectly disclosed about the current stable version
|
||||
that lacks those changes -- as long as the trunk's `readme.txt` points to the correct stable tag.
|
||||
|
||||
If no stable tag is provided, it is assumed that trunk is stable, but you should specify "trunk" if that's where
|
||||
you put the stable version, in order to eliminate any doubt.
|
||||
|
||||
== Installation ==
|
||||
|
||||
This section describes how to install the plugin and get it working.
|
||||
|
||||
e.g.
|
||||
|
||||
1. Upload `plugin-name.php` to the `/wp-content/plugins/` directory
|
||||
1. Activate the plugin through the 'Plugins' menu in WordPress
|
||||
1. Place `<?php do_action('plugin_name_hook'); ?>` in your templates
|
||||
|
||||
== Frequently Asked Questions ==
|
||||
|
||||
= A question that someone might have =
|
||||
|
||||
An answer to that question.
|
||||
|
||||
= What about foo bar? =
|
||||
|
||||
Answer to foo bar dilemma.
|
||||
|
||||
== Screenshots ==
|
||||
|
||||
1. This screen shot description corresponds to screenshot-1.(png|jpg|jpeg|gif). Note that the screenshot is taken from
|
||||
the /assets directory or the directory that contains the stable readme.txt (tags or trunk). Screenshots in the /assets
|
||||
directory take precedence. For example, `/assets/screenshot-1.png` would win over `/tags/4.3/screenshot-1.png`
|
||||
(or jpg, jpeg, gif).
|
||||
2. This is the second screen shot
|
||||
|
||||
== Changelog ==
|
||||
|
||||
= 1.0 =
|
||||
* A change since the previous version.
|
||||
* Another change.
|
||||
|
||||
= 0.5 =
|
||||
* List versions from most recent at top to oldest at bottom.
|
||||
|
||||
== Upgrade Notice ==
|
||||
|
||||
= 1.0 =
|
||||
Upgrade notices describe the reason a user should upgrade. No more than 300 characters.
|
||||
|
||||
= 0.5 =
|
||||
This version fixes a security related bug. Upgrade immediately.
|
||||
|
||||
== Arbitrary section ==
|
||||
|
||||
You may provide arbitrary sections, in the same format as the ones above. This may be of use for extremely complicated
|
||||
plugins where more information needs to be conveyed that doesn't fit into the categories of "description" or
|
||||
"installation." Arbitrary sections will be shown below the built-in sections outlined above.
|
||||
|
||||
== A brief Markdown Example ==
|
||||
|
||||
Ordered list:
|
||||
|
||||
1. Some feature
|
||||
1. Another feature
|
||||
1. Something else about the plugin
|
||||
|
||||
Unordered list:
|
||||
|
||||
* something
|
||||
* something else
|
||||
* third thing
|
||||
|
||||
Here's a link to [WordPress](http://wordpress.org/ "Your favorite software") and one to [Markdown's Syntax Documentation][markdown syntax].
|
||||
Titles are optional, naturally.
|
||||
|
||||
[markdown syntax]: http://daringfireball.net/projects/markdown/syntax
|
||||
"Markdown is what the parser uses to process much of the readme file"
|
||||
|
||||
Markdown uses email style notation for blockquotes and I've been told:
|
||||
> Asterisks for *emphasis*. Double it up for **strong**.
|
||||
|
||||
`<?php code(); // goes in backticks ?>`
|
Loading…
Add table
Add a link
Reference in a new issue