Skip to content

This script generates a Rails scaffold based on an existing table

Notifications You must be signed in to change notification settings

ahe/reverse_scaffold

Folders and files

NameName
Last commit message
Last commit date

Latest commit

author
Anthony Heukmes
Jun 21, 2012
5745f98 · Jun 21, 2012

History

6 Commits
Jun 21, 2012
May 20, 2012

Repository files navigation

Copy the reverse_scaffold file into the script folder of your Rails app.

Let's say you have a users table in your db with the following columns : id, pseudo, email, password

A call to reverse_scaffold :

ruby script/reverse_scaffold users user 

Will execute : 

ruby script/generate scaffold user id:integer pseudo:string email:string password:string



Synopsis
--------
  The reverse_scaffold script executes a Rails scaffold based on an existing table.


Usage
-----
  ruby script/reverse_scaffold table_name model_name


Examples
--------
  ruby script/reverse_scaffold users user


Options
-------
  -h, --help          Displays help message
  -r, --rspec         Generates rspec_scaffold
  -V, --verbose       Outputs the commands being executed by reverse_scaffold
  -v, --version       Display version information about this script
  --primary-key name  Specify diffent Primary Key name than 'id'


Author
------
  Anthony Heukmes
  http://2dconcept.com
  http://github.com/ahe

Modified in 2012 by
--------------------
  Hisakazu Ishibashi 
  - kazutron@gmail.com, 
  - http://github.com/hisapy
  - http://twitter.com/hisa_py

Changes
-------

Basically, modified the script to support Rails 3.2.2 and added a few fixes and features:
	1. Removed Rdoc/Usage because it is not supported on Rails 3.2.2
	2. Fixed the --verbose option. When this option was passed to the program the scaffold was not being generated.
  	3. Removed the id field from the list of fields to be generated
  	4. Modified the way to add a path to $LOAD_PATH to require 'environment'
   	5. Removed the --skip-migration option from the coded command.
   	6. -- skip-migration option is now a program argument.
   	7. Moved the require environment just when necessary to improve responsiveness when not performing the scaffold generation.
   	8. Camelize and underscore are now user's responsability (actually the code that camelized and/or underscored was not working for me so I just removed it... sorry)

TODO:
-----
   1. The table name created by the scaffold does not match the one specified in the table_name program arg. In some situations it would be good to specify a switch to indicate that the table name created in migrations file be the one entered by the user, and also, need to specify in model by set_table_name method.
   2. The set_primary_key is not written in the model created by rails generate scaffold, which means you manually have to write it to make edit/show actions work.


Copyright
---------
  Copyright (c) 2009 Anthony Heukmes. Licensed under the MIT License


About

This script generates a Rails scaffold based on an existing table

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages