Title: wp scaffold cpt
Published: December 18, 2025
Last modified: June 2, 2026

---

# 󠀁[wp scaffold cpt ](https://developer.wordpress.org/cli/commands/scaffold/cpt/)󠁿

Generates PHP code for registering a custom post type.

## In this article

 * [Options](https://developer.wordpress.org/cli/commands/scaffold/cpt/?output_format=md#options)
 * [Examples](https://developer.wordpress.org/cli/commands/scaffold/cpt/?output_format=md#examples)
 * [Global Parameters](https://developer.wordpress.org/cli/commands/scaffold/cpt/?output_format=md#global-parameters)

[ Back to top](https://developer.wordpress.org/cli/commands/scaffold/cpt/?output_format=md#wp--skip-link--target)

 [ View Open Issues (0) ](https://github.com/login?return_to=%2Fissues%3Fq%3Dlabel%3Acommand%3Ascaffold-cpt+sort%3Aupdated-desc+org%3Awp-cli+is%3Aopen)
[ View Closed Issues (0) ](https://github.com/login?return_to=%2Fissues%3Fq%3Dlabel%3Acommand%3Ascaffold-cpt+sort%3Aupdated-desc+org%3Awp-cli+is%3Aclosed)

This is an alias for `wp scaffold post-type`.

### 󠀁[Options](https://developer.wordpress.org/cli/commands/scaffold/cpt/?output_format=md#options)󠁿

 See the [argument syntax](https://make.wordpress.org/cli/handbook/references/argument-syntax/)
reference for a detailed explanation of the syntax conventions used.  <slug> The
internal name of the post type. [--label=<label>] The text used to translate the
update messages. [--textdomain=<textdomain>] The textdomain to use for the labels.[--
dashicon=<dashicon>] The dashicon to use in the menu. [--theme] Create a file in
the active theme directory, instead of sending to STDOUT. Specify a theme with `--
theme=<theme>` to have the file placed in that theme. [--plugin=<plugin>] Create
a file in the given plugin’s directory, instead of sending to STDOUT. [--raw] Just
generate the `register_post_type()` call and nothing else. [--force] Overwrite files
that already exist.

### 󠀁[Examples](https://developer.wordpress.org/cli/commands/scaffold/cpt/?output_format=md#examples)󠁿

    ```
    # Generate a 'movie' post type for the 'simple-life' theme
    $ wp scaffold post-type movie --label=Movie --theme=simple-life
    Success: Created '/var/www/example.com/public_html/wp-content/themes/simple-life/post-types/movie.php'.
    ```

### 󠀁[Global Parameters](https://developer.wordpress.org/cli/commands/scaffold/cpt/?output_format=md#global-parameters)󠁿

 These [global parameters](https://make.wordpress.org/cli/handbook/config/) have
the same behavior across all commands and affect how WP-CLI interacts with WordPress.

  |  **Argument** |  **Description** |  
   |  `--path=<path>` |  Path to the WordPress files. |  
 |  `--url=<url>` |  Pretend request came from given URL. In multisite, this argument is how the target site is specified. |  
 |  `--ssh=[<scheme>:][<user>@]<host\|container>[:<port>][<path>]` |  Perform operation against a remote server over SSH (or a container using scheme of “docker”, “docker-compose”, “docker-compose-run”, “vagrant”). |  
 |  `--http=<http>` |  Perform operation against a remote WordPress installation over HTTP. |  
 |  `--user=<id\|login\|email>` |  Set the WordPress user. |  
 |  `--skip-plugins[=<plugins>]` |  Skip loading all plugins, or a comma-separated list of plugins. Note: mu-plugins are still loaded. |  
 |  `--skip-themes[=<themes>]` |  Skip loading all themes, or a comma-separated list of themes. |  
 |  `--skip-packages` |  Skip loading all installed packages. |  
 |  `--require=<path>` |  Load PHP file before running the command (may be used more than once). |  
 |  `--exec=<php-code>` |  Execute PHP code before running the command (may be used more than once). |  
 |  `--context=<context>` |  Load WordPress in a given context. |  
 |  `--[no-]color` |  Whether to colorize the output. |  
 |  `--debug[=<group>]` |  Show all PHP errors and add verbosity to WP-CLI output. Built-in groups include: bootstrap, commandfactory, and help. |  
 |  `--prompt[=<assoc>]` |  Prompt the user to enter values for all command arguments, or a subset specified as comma-separated values. |  
 |  `--quiet` |  Suppress informational messages. |

 _Command documentation is regenerated at every release. To add or update an example,
please submit a pull request against the corresponding part of the codebase._