From dc0a19be1e66851563010232663023f300a717ce Mon Sep 17 00:00:00 2001 From: Elad Kaplan Date: Mon, 6 Jan 2025 09:35:49 +0200 Subject: [PATCH 1/3] Enhance help text with command examples for migration and controller generation --- src/cli.rs | 65 +++++++++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 64 insertions(+), 1 deletion(-) diff --git a/src/cli.rs b/src/cli.rs index 37bbf23c7..e4134102e 100644 --- a/src/cli.rs +++ b/src/cli.rs @@ -178,6 +178,21 @@ enum ComponentArg { #[cfg(feature = "with-db")] /// Generates a new model file for defining the data structure of your /// application, and test file logic. + #[command(after_help = format!( + "{} + - Generate empty model: + $ cargo loco g model posts + + - Generate model with fields: + $ cargo loco g model posts title:string! content:text + + - Generate model with references: + $ cargo loco g model movies long_title:string added_by:references:users director:references + # reference director is in singular: director:references + # reference added_by is in singular, the referenced model is plural: added_by:references:users +", + "Examples:".bold().underline() +))] Model { /// Name of the thing to generate name: String, @@ -192,15 +207,41 @@ enum ComponentArg { }, #[cfg(feature = "with-db")] /// Generates a new migration file + #[command(after_help = format!("{} + - Create a new table: + $ cargo loco g migration CreatePosts title:string + # Creates a migration to add a 'posts' table with a 'title' column of type string. + + - Add columns to an existing table: + $ cargo loco g migration AddNameAndAgeToUsers name:string age:int + # Adds 'name' (string) and 'age' (integer) columns to the 'users' table. + + - Remove columns from a table: + $ cargo loco g migration RemoveNameAndAgeFromUsers name:string age:int + # Removes 'name' and 'age' columns from the 'users' table. + + - Add a foreign key reference: + $ cargo loco g migration AddUserRefToPosts user:references + # Adds a reference to the 'users' table in the 'posts' table. + + - Create a join table: + $ cargo loco g migration CreateJoinTableUsersAndGroups count:int + # Creates a join table 'users_groups' with an additional 'count' column. + + - Create an empty migration: + $ cargo loco g migration FixUsersTable + # Creates a blank migration file for custom edits to the 'users' table.", "Examples:".bold().underline()))] Migration { /// Name of the migration to generate name: String, /// Table fields, eg. title:string hits:int - #[clap(value_parser = parse_key_val::)] + #[clap(value_parser = parse_key_val::, )] fields: Vec<(String, String)>, }, #[cfg(feature = "with-db")] /// Generates a CRUD scaffold, model and controller + #[command(after_help = format!("{} + $ cargo loco g model posts title:string! user:references --api", "Examples:".bold().underline()))] Scaffold { /// Name of the thing to generate name: String, @@ -226,6 +267,16 @@ enum ComponentArg { api: bool, }, /// Generate a new controller with the given controller name, and test file. + #[command(after_help = format!( + "{} + - Generate an empty controller: + $ cargo loco generate controller posts --api + + - Generate a controller with actions: + $ cargo loco generate controller posts --api list remove update +", + "Examples:".bold().underline() +))] Controller { /// Name of the thing to generate name: String, @@ -274,6 +325,18 @@ enum ComponentArg { }, /// Override templates and allows you to take control of them. You can always go back when deleting the local template. + #[command(after_help = format!("{} + - Override a Specific File: + * cargo loco generate override scaffold/api/controller.t + * cargo loco generate override migration/add_columns.t + + - Override All Files in a Folder: + * cargo loco generate override scaffold/htmx + * cargo loco generate override task + + - Override All templates: + * cargo loco generate override . +", "Examples:".bold().underline()))] Override { /// The path to a specific template or directory to copy. template_path: Option, From caba490fe1876db4b57657f75873ad0751e6a201 Mon Sep 17 00:00:00 2001 From: Elad Kaplan Date: Mon, 6 Jan 2025 09:57:40 +0200 Subject: [PATCH 2/3] adding steps command after running generate migration --- src/cli.rs | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/src/cli.rs b/src/cli.rs index e4134102e..ad0eed4fc 100644 --- a/src/cli.rs +++ b/src/cli.rs @@ -230,7 +230,14 @@ enum ComponentArg { - Create an empty migration: $ cargo loco g migration FixUsersTable - # Creates a blank migration file for custom edits to the 'users' table.", "Examples:".bold().underline()))] + # Creates a blank migration file for custom edits to the 'users' table. + +After running the migration, follow these steps to complete the process: + - Apply the migration: + $ cargo loco db migrate + - Generate the model entities: + $ cargo loco db entities +", "Examples:".bold().underline()))] Migration { /// Name of the migration to generate name: String, From bd4653939cc5715c0202ba486560b128a0a5f7fc Mon Sep 17 00:00:00 2001 From: "Dotan J. Nahum" Date: Wed, 8 Jan 2025 09:08:20 +0200 Subject: [PATCH 3/3] Update cli.rs --- src/cli.rs | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/cli.rs b/src/cli.rs index ad0eed4fc..63b68a755 100644 --- a/src/cli.rs +++ b/src/cli.rs @@ -187,9 +187,9 @@ enum ComponentArg { $ cargo loco g model posts title:string! content:text - Generate model with references: - $ cargo loco g model movies long_title:string added_by:references:users director:references - # reference director is in singular: director:references - # reference added_by is in singular, the referenced model is plural: added_by:references:users + $ cargo loco g model movies long_title:string director:references award:references:prize_id + # 'director:references' references the 'directors' table with 'director_id' on 'movies' + # 'award:references:prize_id' references the 'awards' table with 'prize_id' on 'movies' ", "Examples:".bold().underline() ))]