Professional CodeIgniter, Thomas Myer
Chapter 1: Welcome to the MVC World
3
Six months later, the programmer gets a call from the client, and the problems begin -- not big problems
at first, but they have a tendency to snowball. The client wants to add a few database fields, change the
way the interface looks, and make the application more flexible in certain ways. Out loud, the
programmer tells the client that everything is OK, but inside, a sense of low - level panic is brewing.
Why? Because the programmer barely remembers any details about the project in question six months
later. Honestly, the programmer has worked on 10 other applications since that project ended,
amounting to many thousands of lines of code written, rewritten, debugged, refactored, and rewritten
again to meet the needs of changing requirements. This is not to mention that the programmer isn ' t
exactly indifferent to learning about programming, so he ' s been reading books on the subject and
applying what he ' s learned to current projects. The programmer knows that the approach he took with
this particular project is off the mark. The approach wasn ' t wrong , in a strictly objective way (there are
many ways to skin a cat, after all), but it sacrificed long - term support and flexibility in favor of ad hoc
construction and initial speed.
Without a doubt, cleaning up the previous work will mean digging through the code to untangle PHP
snippets, SQL queries, and XHTML markup; retesting everything to make sure it ' s working right; and making
sure that the application code and interface match the database. It ' s also likely that the client will change her
mind about many things along the way, requiring many course corrections (read: " rewriting code " ).
Even if the request from the client is relatively simple, involving a new skin or HTML layout, the
programmer could find himself carefully picking through code to make sure no vital functionality is
erased. The requests get more complex from there, and all of them are filed under " Let ' s hope they don ' t
ask for that " : supporting mobile devices, displaying content in foreign languages, rendering different
views of the same data (such as pie chart versus spreadsheet), adding extensive Ajax controls, and so on.
So the programmer takes on the project, knowing full well that the relationship with the client is the
most important thing -- that, and a sense of pride that won ' t let him hand the project over to a
completely new programmer, who will probably screw it up.
The first thing he decides to take on is that crazy SQL query right on the home page. The thing to do here
is to create a functions.php file in which he stores all the functions. The function for that home page
content (notice the minimal exception handling) ends up looking like this:
<
?php
function fetchHomePage(){
$sql = "select * from pages where status='live' and type='home' limit 1";
$result = mysql_query($sql);
while($data = mysql_fetch_object($result)){
$hp[`title'] = $data-
>
title;
$hp[`css'] = $data-
>
css;
$hp[`bodycopy'] = $data-
>
bodycopy;
$hp[`kw'] = $data-
>
keywords;
$hp[`desc'] = $data-
>
description;
}
if (count($hp)){
return $hp;
c01.indd 3
c01.indd 3
6/10/08 5:29:57 PM
6/10/08 5:29:57 PM