435 lines
17 KiB
HTML
435 lines
17 KiB
HTML
|
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
|
||
|
<html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en">
|
||
|
<head>
|
||
|
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
|
||
|
<title>A Guide to The Rails Command Line</title>
|
||
|
<!--[if lt IE 8]>
|
||
|
<script src="http://ie7-js.googlecode.com/svn/version/2.0(beta3)/IE8.js" type="text/javascript"></script>
|
||
|
<![endif]-->
|
||
|
<link href="stylesheets/base.css" media="screen" rel="Stylesheet" type="text/css" />
|
||
|
<link href="stylesheets/forms.css" media="screen" rel="Stylesheet" type="text/css" />
|
||
|
<link href="stylesheets/more.css" media="screen" rel="Stylesheet" type="text/css" />
|
||
|
<style type="text/css">
|
||
|
div#container {
|
||
|
max-width: 900px;
|
||
|
padding-bottom: 3em;
|
||
|
}
|
||
|
|
||
|
div#content {
|
||
|
margin-left: 200px;
|
||
|
}
|
||
|
|
||
|
div#container.notoc {
|
||
|
max-width: 600px;
|
||
|
}
|
||
|
|
||
|
.notoc div#content {
|
||
|
margin-left: 0;
|
||
|
}
|
||
|
|
||
|
pre {
|
||
|
line-height: 1.4em;
|
||
|
}
|
||
|
|
||
|
#content p tt {
|
||
|
background: #eeeeee;
|
||
|
border: solid 1px #cccccc;
|
||
|
padding: 3px;
|
||
|
}
|
||
|
|
||
|
dt {
|
||
|
font-weight: bold;
|
||
|
}
|
||
|
|
||
|
#content dt tt {
|
||
|
font-size: 10pt;
|
||
|
}
|
||
|
|
||
|
dd {
|
||
|
margin-left: 3em;
|
||
|
}
|
||
|
|
||
|
#content dt tt, #content pre tt {
|
||
|
background: none;
|
||
|
padding: 0;
|
||
|
border: 0;
|
||
|
}
|
||
|
|
||
|
#content .olist ol {
|
||
|
margin-left: 2em;
|
||
|
}
|
||
|
|
||
|
#header {
|
||
|
position: relative;
|
||
|
max-width: 840px;
|
||
|
margin-left: auto;
|
||
|
margin-right: auto;
|
||
|
}
|
||
|
|
||
|
#header.notoc {
|
||
|
max-width: 580px;
|
||
|
}
|
||
|
|
||
|
#logo {
|
||
|
position: absolute;
|
||
|
left: 10px;
|
||
|
top: 10px;
|
||
|
width: 110px;
|
||
|
height: 140px;
|
||
|
}
|
||
|
|
||
|
div#header h1#site_title {
|
||
|
background: url('images/ruby_on_rails_by_mike_rundle2.gif') top left no-repeat;
|
||
|
position: absolute;
|
||
|
width: 392px;
|
||
|
height: 55px;
|
||
|
left: 145px;
|
||
|
top: 20px;
|
||
|
margin: 0;
|
||
|
padding: 0;
|
||
|
}
|
||
|
|
||
|
#site_title span {
|
||
|
display: none;
|
||
|
}
|
||
|
|
||
|
#site_title_tagline {
|
||
|
display: none;
|
||
|
}
|
||
|
|
||
|
ul#navMain {
|
||
|
position: absolute;
|
||
|
margin: 0;
|
||
|
padding: 0;
|
||
|
top: 97px;
|
||
|
left: 145px;
|
||
|
}
|
||
|
|
||
|
.left-floaty, .right-floaty {
|
||
|
padding: 15px;
|
||
|
}
|
||
|
|
||
|
.admonitionblock,
|
||
|
.tableblock {
|
||
|
margin-left: 1em;
|
||
|
margin-right: 1em;
|
||
|
margin-top: 0.25em;
|
||
|
margin-bottom: 1em;
|
||
|
}
|
||
|
|
||
|
.admonitionblock .icon {
|
||
|
padding-right: 8px;
|
||
|
}
|
||
|
|
||
|
.admonitionblock .content {
|
||
|
border: solid 1px #ffda78;
|
||
|
background: #fffebd;
|
||
|
padding: 10px;
|
||
|
padding-top: 8px;
|
||
|
padding-bottom: 8px;
|
||
|
}
|
||
|
|
||
|
.admonitionblock .title {
|
||
|
font-size: 140%;
|
||
|
margin-bottom: 0.5em;
|
||
|
}
|
||
|
|
||
|
.tableblock table {
|
||
|
border: solid 1px #aaaaff;
|
||
|
background: #f0f0ff;
|
||
|
}
|
||
|
|
||
|
.tableblock th {
|
||
|
background: #e0e0e0;
|
||
|
}
|
||
|
|
||
|
.tableblock th,
|
||
|
.tableblock td {
|
||
|
padding: 3px;
|
||
|
padding-left: 5px;
|
||
|
padding-right: 5px;
|
||
|
}
|
||
|
|
||
|
.sidebarblock {
|
||
|
margin-top: 0.25em;
|
||
|
margin: 1em;
|
||
|
border: solid 1px #ccccbb;
|
||
|
padding: 8px;
|
||
|
background: #ffffe0;
|
||
|
}
|
||
|
|
||
|
.sidebarblock .sidebar-title {
|
||
|
font-size: 140%;
|
||
|
font-weight: 600;
|
||
|
margin-bottom: 0.3em;
|
||
|
}
|
||
|
|
||
|
.sidebarblock .sidebar-content > .para:last-child > p {
|
||
|
margin-bottom: 0;
|
||
|
}
|
||
|
|
||
|
.sidebarblock .sidebar-title a {
|
||
|
text-decoration: none;
|
||
|
}
|
||
|
|
||
|
.sidebarblock .sidebar-title a:hover {
|
||
|
text-decoration: underline;
|
||
|
}
|
||
|
|
||
|
</style>
|
||
|
</head>
|
||
|
<body>
|
||
|
<div id="header" >
|
||
|
<div id="logo">
|
||
|
<a href="index.html" title="Ruby on Rails"><img src="images/rails_logo_remix.gif" alt="Rails" height="140" width="110" /></a>
|
||
|
</div>
|
||
|
|
||
|
<h1 id="site_title"><span>Ruby on Rails</span></h1>
|
||
|
<h2 id="site_title_tagline">Sustainable productivity for web-application development</h2>
|
||
|
|
||
|
<ul id="navMain">
|
||
|
<li class="first-child"><a href="http://www.rubyonrails.org/" title="Ruby on Rails" class="ruby_on_rails">Ruby on Rails</a></li>
|
||
|
<li><a class="manuals" href="index.html" title="Manuals Index">Guides Index</a></li>
|
||
|
</ul>
|
||
|
</div>
|
||
|
|
||
|
<div id="container">
|
||
|
|
||
|
<div id="sidebar">
|
||
|
<h2>Chapters</h2>
|
||
|
<ol>
|
||
|
<li>
|
||
|
<a href="#_command_line_basics">Command Line Basics</a>
|
||
|
<ul>
|
||
|
|
||
|
<li><a href="#_rails">rails</a></li>
|
||
|
|
||
|
<li><a href="#_server">server</a></li>
|
||
|
|
||
|
<li><a href="#_generate">generate</a></li>
|
||
|
|
||
|
</ul>
|
||
|
</li>
|
||
|
</ol>
|
||
|
</div>
|
||
|
|
||
|
<div id="content">
|
||
|
<h1>A Guide to The Rails Command Line</h1>
|
||
|
<div id="preamble">
|
||
|
<div class="sectionbody">
|
||
|
<div class="para"><p>Rails comes with every command line tool you'll need to</p></div>
|
||
|
<div class="ilist"><ul>
|
||
|
<li>
|
||
|
<p>
|
||
|
Create a Rails application
|
||
|
</p>
|
||
|
</li>
|
||
|
<li>
|
||
|
<p>
|
||
|
Generate models, controllers, database migrations, and unit tests
|
||
|
</p>
|
||
|
</li>
|
||
|
<li>
|
||
|
<p>
|
||
|
Start a development server
|
||
|
</p>
|
||
|
</li>
|
||
|
<li>
|
||
|
<p>
|
||
|
Mess with objects through an interactive shell
|
||
|
</p>
|
||
|
</li>
|
||
|
<li>
|
||
|
<p>
|
||
|
Profile and benchmark your new creation
|
||
|
</p>
|
||
|
</li>
|
||
|
</ul></div>
|
||
|
<div class="para"><p>… and much, much more! (Buy now!)</p></div>
|
||
|
<div class="para"><p>This tutorial assumes you have basic Rails knowledge from reading the Getting Started with Rails Guide.</p></div>
|
||
|
</div>
|
||
|
</div>
|
||
|
<h2 id="_command_line_basics">1. Command Line Basics</h2>
|
||
|
<div class="sectionbody">
|
||
|
<div class="para"><p>There are a few commands that are absolutely critical to your everyday usage of Rails. In the order of how much you'll probably use them are:</p></div>
|
||
|
<div class="ilist"><ul>
|
||
|
<li>
|
||
|
<p>
|
||
|
console
|
||
|
</p>
|
||
|
</li>
|
||
|
<li>
|
||
|
<p>
|
||
|
server
|
||
|
</p>
|
||
|
</li>
|
||
|
<li>
|
||
|
<p>
|
||
|
rake
|
||
|
</p>
|
||
|
</li>
|
||
|
<li>
|
||
|
<p>
|
||
|
generate
|
||
|
</p>
|
||
|
</li>
|
||
|
<li>
|
||
|
<p>
|
||
|
rails
|
||
|
</p>
|
||
|
</li>
|
||
|
</ul></div>
|
||
|
<div class="para"><p>Let's create a simple Rails application to step through each of these commands in context.</p></div>
|
||
|
<h3 id="_rails">1.1. rails</h3>
|
||
|
<div class="para"><p>The first thing we'll want to do is create a new Rails application by running the <tt>rails</tt> command after installing Rails.</p></div>
|
||
|
<div class="admonitionblock">
|
||
|
<table><tr>
|
||
|
<td class="icon">
|
||
|
<img src="./images/icons/note.png" alt="Note" />
|
||
|
</td>
|
||
|
<td class="content">You know you need the rails gem installed by typing <tt>gem install rails</tt> first, right? Okay, okay, just making sure.</td>
|
||
|
</tr></table>
|
||
|
</div>
|
||
|
<div class="listingblock">
|
||
|
<div class="content"><!-- Generator: GNU source-highlight 2.9
|
||
|
by Lorenzo Bettini
|
||
|
http://www.lorenzobettini.it
|
||
|
http://www.gnu.org/software/src-highlite -->
|
||
|
<pre><tt>$ rails commandsapp
|
||
|
|
||
|
create
|
||
|
create app/controllers
|
||
|
create app/helpers
|
||
|
create app/models
|
||
|
<span style="color: #990000">...</span>
|
||
|
<span style="color: #990000">...</span>
|
||
|
create log/production<span style="color: #990000">.</span>log
|
||
|
create log/development<span style="color: #990000">.</span>log
|
||
|
create log/test<span style="color: #990000">.</span>log
|
||
|
</tt></pre></div></div>
|
||
|
<div class="para"><p>Rails will set you up with what seems like a huge amount of stuff for such a tiny command! You've got the entire Rails directory structure now with all the code you need to run our simple application right out of the box.</p></div>
|
||
|
<div class="admonitionblock">
|
||
|
<table><tr>
|
||
|
<td class="icon">
|
||
|
<img src="./images/icons/note.png" alt="Note" />
|
||
|
</td>
|
||
|
<td class="content">This output will seem very familiar when we get to the <tt>generate</tt> command. Creepy foreshadowing!</td>
|
||
|
</tr></table>
|
||
|
</div>
|
||
|
<h3 id="_server">1.2. server</h3>
|
||
|
<div class="para"><p>Let's try it! The <tt>server</tt> command launches a small web server written in Ruby named WEBrick which was also installed when you installed Rails. You'll use this any time you want to view your work through a web browser.</p></div>
|
||
|
<div class="admonitionblock">
|
||
|
<table><tr>
|
||
|
<td class="icon">
|
||
|
<img src="./images/icons/note.png" alt="Note" />
|
||
|
</td>
|
||
|
<td class="content">WEBrick isn't your only option for serving Rails. We'll get to that in a later section. [XXX: which section]</td>
|
||
|
</tr></table>
|
||
|
</div>
|
||
|
<div class="para"><p>Here we'll flex our <tt>server</tt> command, which without any prodding of any kind will run our new shiny Rails app:</p></div>
|
||
|
<div class="listingblock">
|
||
|
<div class="content"><!-- Generator: GNU source-highlight 2.9
|
||
|
by Lorenzo Bettini
|
||
|
http://www.lorenzobettini.it
|
||
|
http://www.gnu.org/software/src-highlite -->
|
||
|
<pre><tt>$ cd commandsapp
|
||
|
$ <span style="color: #990000">.</span>/script/server
|
||
|
<span style="color: #990000">=></span> Booting WEBrick<span style="color: #990000">...</span>
|
||
|
<span style="color: #990000">=></span> Rails <span style="color: #993399">2.2</span><span style="color: #990000">.</span><span style="color: #993399">0</span> application started on http<span style="color: #990000">://</span><span style="color: #993399">0.0</span><span style="color: #990000">.</span><span style="color: #993399">0.0</span><span style="color: #990000">:</span><span style="color: #993399">3000</span>
|
||
|
<span style="color: #990000">=></span> Ctrl-C to shutdown server<span style="color: #990000">;</span> call with --help <span style="font-weight: bold"><span style="color: #0000FF">for</span></span> options
|
||
|
<span style="color: #990000">[</span><span style="color: #993399">2008</span>-<span style="color: #993399">11</span>-<span style="color: #993399">04</span> <span style="color: #993399">10</span><span style="color: #990000">:</span><span style="color: #993399">11</span><span style="color: #990000">:</span><span style="color: #993399">38</span><span style="color: #990000">]</span> INFO WEBrick <span style="color: #993399">1.3</span><span style="color: #990000">.</span><span style="color: #993399">1</span>
|
||
|
<span style="color: #990000">[</span><span style="color: #993399">2008</span>-<span style="color: #993399">11</span>-<span style="color: #993399">04</span> <span style="color: #993399">10</span><span style="color: #990000">:</span><span style="color: #993399">11</span><span style="color: #990000">:</span><span style="color: #993399">38</span><span style="color: #990000">]</span> INFO ruby <span style="color: #993399">1.8</span><span style="color: #990000">.</span><span style="color: #993399">5</span> <span style="color: #990000">(</span><span style="color: #993399">2006</span>-<span style="color: #993399">12</span>-<span style="color: #993399">04</span><span style="color: #990000">)</span> <span style="color: #990000">[</span>i486-linux<span style="color: #990000">]</span>
|
||
|
<span style="color: #990000">[</span><span style="color: #993399">2008</span>-<span style="color: #993399">11</span>-<span style="color: #993399">04</span> <span style="color: #993399">10</span><span style="color: #990000">:</span><span style="color: #993399">11</span><span style="color: #990000">:</span><span style="color: #993399">38</span><span style="color: #990000">]</span> INFO WEBrick<span style="color: #990000">::</span>HTTPServer<span style="font-style: italic"><span style="color: #9A1900">#start: pid=18994 port=3000</span></span>
|
||
|
</tt></pre></div></div>
|
||
|
<div class="para"><p>WHOA. With just three commands we whipped up a Rails server listening on port 3000. Go! Go right now to your browser and go to <a href="http://localhost:3000">http://localhost:3000</a>. I'll wait.</p></div>
|
||
|
<div class="para"><p>See? Cool! It doesn't do much yet, but we'll change that.</p></div>
|
||
|
<h3 id="_generate">1.3. generate</h3>
|
||
|
<div class="para"><p>The <tt>generate</tt> command uses templates to create a whole lot of things. You can always find out what's available by running <tt>generate</tt> by itself. Let's do that:</p></div>
|
||
|
<div class="listingblock">
|
||
|
<div class="content"><!-- Generator: GNU source-highlight 2.9
|
||
|
by Lorenzo Bettini
|
||
|
http://www.lorenzobettini.it
|
||
|
http://www.gnu.org/software/src-highlite -->
|
||
|
<pre><tt>$ <span style="color: #990000">.</span>/script/generate
|
||
|
Usage<span style="color: #990000">:</span> <span style="color: #990000">.</span>/script/generate generator <span style="color: #990000">[</span>options<span style="color: #990000">]</span> <span style="color: #990000">[</span>args<span style="color: #990000">]</span>
|
||
|
|
||
|
<span style="color: #990000">...</span>
|
||
|
<span style="color: #990000">...</span>
|
||
|
|
||
|
Installed Generators
|
||
|
Builtin<span style="color: #990000">:</span> controller<span style="color: #990000">,</span> integration_test<span style="color: #990000">,</span> mailer<span style="color: #990000">,</span> migration<span style="color: #990000">,</span> model<span style="color: #990000">,</span> observer<span style="color: #990000">,</span> performance_test<span style="color: #990000">,</span> plugin<span style="color: #990000">,</span> resource<span style="color: #990000">,</span> scaffold<span style="color: #990000">,</span> session_migration
|
||
|
|
||
|
<span style="color: #990000">...</span>
|
||
|
<span style="color: #990000">...</span>
|
||
|
</tt></pre></div></div>
|
||
|
<div class="admonitionblock">
|
||
|
<table><tr>
|
||
|
<td class="icon">
|
||
|
<img src="./images/icons/note.png" alt="Note" />
|
||
|
</td>
|
||
|
<td class="content">You can install more generators through generator gems, portions of plugins you'll undoubtedly install, and you can even create your own!</td>
|
||
|
</tr></table>
|
||
|
</div>
|
||
|
<div class="para"><p>Using generators will save you a large amount of time by writing <strong>boilerplate code</strong> for you — necessary for the darn thing to work, but not necessary for you to spend time writing. That's what we have computers for, right?</p></div>
|
||
|
<div class="para"><p>Let's make our own controller with the controller generator. But what command should we use? Let's ask the generator:</p></div>
|
||
|
<div class="admonitionblock">
|
||
|
<table><tr>
|
||
|
<td class="icon">
|
||
|
<img src="./images/icons/note.png" alt="Note" />
|
||
|
</td>
|
||
|
<td class="content">All Rails console utilities have help text. For commands that require a lot of input to run correctly, you can just try the command without any parameters (like <tt>rails</tt> or <tt>./script/generate</tt>). For others, you can try adding <tt>—help</tt> or <tt>-h</tt> to the end, as in <tt>./script/server —help</tt>.</td>
|
||
|
</tr></table>
|
||
|
</div>
|
||
|
<div class="listingblock">
|
||
|
<div class="content"><!-- Generator: GNU source-highlight 2.9
|
||
|
by Lorenzo Bettini
|
||
|
http://www.lorenzobettini.it
|
||
|
http://www.gnu.org/software/src-highlite -->
|
||
|
<pre><tt>$ <span style="color: #990000">.</span>/script/generate controller
|
||
|
Usage<span style="color: #990000">:</span> <span style="color: #990000">.</span>/script/generate controller ControllerName <span style="color: #990000">[</span>options<span style="color: #990000">]</span>
|
||
|
|
||
|
<span style="color: #990000">...</span>
|
||
|
<span style="color: #990000">...</span>
|
||
|
|
||
|
Example<span style="color: #990000">:</span>
|
||
|
`<span style="color: #990000">.</span>/script/generate controller CreditCard open debit credit close`
|
||
|
|
||
|
Credit card controller with URLs like /credit_card/debit<span style="color: #990000">.</span>
|
||
|
Controller<span style="color: #990000">:</span> app/controllers/credit_card_controller<span style="color: #990000">.</span>rb
|
||
|
Views<span style="color: #990000">:</span> app/views/credit_card/debit<span style="color: #990000">.</span>html<span style="color: #990000">.</span>erb <span style="color: #990000">[...]</span>
|
||
|
Helper<span style="color: #990000">:</span> app/helpers/credit_card_helper<span style="color: #990000">.</span>rb
|
||
|
Test<span style="color: #990000">:</span> test/functional/credit_card_controller_test<span style="color: #990000">.</span>rb
|
||
|
|
||
|
Modules Example<span style="color: #990000">:</span>
|
||
|
`<span style="color: #990000">.</span>/script/generate controller <span style="color: #FF0000">'admin/credit_card'</span> <span style="font-weight: bold"><span style="color: #0000FF">suspend</span></span> late_fee`
|
||
|
|
||
|
Credit card admin controller with URLs /admin/credit_card/suspend<span style="color: #990000">.</span>
|
||
|
Controller<span style="color: #990000">:</span> app/controllers/admin/credit_card_controller<span style="color: #990000">.</span>rb
|
||
|
Views<span style="color: #990000">:</span> app/views/admin/credit_card/debit<span style="color: #990000">.</span>html<span style="color: #990000">.</span>erb <span style="color: #990000">[...]</span>
|
||
|
Helper<span style="color: #990000">:</span> app/helpers/admin/credit_card_helper<span style="color: #990000">.</span>rb
|
||
|
Test<span style="color: #990000">:</span> test/functional/admin/credit_card_controller_test<span style="color: #990000">.</span>rb
|
||
|
</tt></pre></div></div>
|
||
|
<div class="para"><p>Ah, the controller generator is expecting parameters in the form of <tt>generate controller ControllerName action1 action2</tt>. Let's make a <tt>Greetings</tt> controller with an action of <strong>hello</strong>, which will say something nice to us.</p></div>
|
||
|
<div class="listingblock">
|
||
|
<div class="content"><!-- Generator: GNU source-highlight 2.9
|
||
|
by Lorenzo Bettini
|
||
|
http://www.lorenzobettini.it
|
||
|
http://www.gnu.org/software/src-highlite -->
|
||
|
<pre><tt>$ <span style="color: #990000">.</span>/script/generate controller Greeting hello
|
||
|
exists app/controllers<span style="color: #990000">/</span>
|
||
|
exists app/helpers<span style="color: #990000">/</span>
|
||
|
create app/views/greeting
|
||
|
exists test/functional<span style="color: #990000">/</span>
|
||
|
create app/controllers/greetings_controller<span style="color: #990000">.</span>rb
|
||
|
create test/functional/greetings_controller_test<span style="color: #990000">.</span>rb
|
||
|
create app/helpers/greetings_helper<span style="color: #990000">.</span>rb
|
||
|
create app/views/greetings/hello<span style="color: #990000">.</span>html<span style="color: #990000">.</span>erb
|
||
|
</tt></pre></div></div>
|
||
|
<div class="para"><p>Look there! Now what all did this generate? It looks like it made sure a bunch of directories were in our application, and created a controller file, a functional test file, a helper for the view, and a view file. All from one command!</p></div>
|
||
|
</div>
|
||
|
|
||
|
</div>
|
||
|
</div>
|
||
|
</body>
|
||
|
</html>
|