Changing EOL style to LF
diff --git a/system/database/drivers/oci8/index.html b/system/database/drivers/oci8/index.html
index 065d2da..c942a79 100644
--- a/system/database/drivers/oci8/index.html
+++ b/system/database/drivers/oci8/index.html
@@ -1,10 +1,10 @@
-<html>

-<head>

-	<title>403 Forbidden</title>

-</head>

-<body>

-

-<p>Directory access is forbidden.</p>

-

-</body>

+<html>
+<head>
+	<title>403 Forbidden</title>
+</head>
+<body>
+
+<p>Directory access is forbidden.</p>
+
+</body>
 </html>
\ No newline at end of file
diff --git a/system/database/drivers/oci8/oci8_driver.php b/system/database/drivers/oci8/oci8_driver.php
index 0c14677..0629a59 100644
--- a/system/database/drivers/oci8/oci8_driver.php
+++ b/system/database/drivers/oci8/oci8_driver.php
@@ -1,737 +1,737 @@
-<?php  if ( ! defined('BASEPATH')) exit('No direct script access allowed');

-/**

- * CodeIgniter

- *

- * An open source application development framework for PHP 4.3.2 or newer

- *

- * @package	 	CodeIgniter

- * @author	  	ExpressionEngine Dev Team

- * @copyright   Copyright (c) 2008, EllisLab, Inc.

- * @license	 	http://codeigniter.com/user_guide/license.html

- * @link		http://codeigniter.com

- * @since	   	Version 1.0

- * @filesource

- */

-

-// ------------------------------------------------------------------------

-

-/**

- * oci8 Database Adapter Class

- *

- * Note: _DB is an extender class that the app controller

- * creates dynamically based on whether the active record

- * class is being used or not.

- *

- * @package	 	CodeIgniter

- * @subpackage  Drivers

- * @category	Database

- * @author	  	ExpressionEngine Dev Team

- * @link		http://codeigniter.com/user_guide/database/

- */

-

-/**

- * oci8 Database Adapter Class

- *

- * This is a modification of the DB_driver class to

- * permit access to oracle databases

- *

- * NOTE: this uses the PHP 4 oci methods

- *

- * @author	  Kelly McArdle

- *

- */

-

-class CI_DB_oci8_driver extends CI_DB {

-

-	var $dbdriver = 'oci8';

-	

-	// The character used for excaping

-	var $_escape_char = '"';

-

-	/**

-	 * The syntax to count rows is slightly different across different

-	 * database engines, so this string appears in each driver and is

-	 * used for the count_all() and count_all_results() functions.

-	 */

-	var $_count_string = "SELECT COUNT(1) AS ";

-	var $_random_keyword = ' ASC'; // not currently supported

-

-	// Set "auto commit" by default

-	var $_commit = OCI_COMMIT_ON_SUCCESS;

-

-	// need to track statement id and cursor id

-	var $stmt_id;

-	var $curs_id;

-

-	// if we use a limit, we will add a field that will

-	// throw off num_fields later

-	var $limit_used;

-

-	/**

-	 * Non-persistent database connection

-	 *

-	 * @access  private called by the base class

-	 * @return  resource

-	 */

-	function db_connect()

-	{

-		return @ocilogon($this->username, $this->password, $this->hostname);

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Persistent database connection

-	 *

-	 * @access  private called by the base class

-	 * @return  resource

-	 */

-	function db_pconnect()

-	{

-		return @ociplogon($this->username, $this->password, $this->hostname);

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Select the database

-	 *

-	 * @access  private called by the base class

-	 * @return  resource

-	 */

-	function db_select()

-	{

-		return TRUE;

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Set client character set

-	 *

-	 * @access	public

-	 * @param	string

-	 * @param	string

-	 * @return	resource

-	 */

-	function db_set_charset($charset, $collation)

-	{

-		// @todo - add support if needed

-		return TRUE;

-	}

-

-	// --------------------------------------------------------------------

-	

-	/**

-	 * Version number query string

-	 *

-	 * @access  public

-	 * @return  string

-	 */

-	function _version()

-	{

-		return ociserverversion($this->conn_id);

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Execute the query

-	 *

-	 * @access  private called by the base class

-	 * @param   string  an SQL query

-	 * @return  resource

-	 */

-	function _execute($sql)

-	{

-		// oracle must parse the query before it is run. All of the actions with

-		// the query are based on the statement id returned by ociparse

-		$this->stmt_id = FALSE;

-		$this->_set_stmt_id($sql);

-		ocisetprefetch($this->stmt_id, 1000);

-		return @ociexecute($this->stmt_id, $this->_commit);

-	}

-

-	/**

-	 * Generate a statement ID

-	 *

-	 * @access  private

-	 * @param   string  an SQL query

-	 * @return  none

-	 */

-	function _set_stmt_id($sql)

-	{

-		if ( ! is_resource($this->stmt_id))

-		{

-			$this->stmt_id = ociparse($this->conn_id, $this->_prep_query($sql));

-		}

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Prep the query

-	 *

-	 * If needed, each database adapter can prep the query string

-	 *

-	 * @access  private called by execute()

-	 * @param   string  an SQL query

-	 * @return  string

-	 */

-	function _prep_query($sql)

-	{

-		return $sql;

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * getCursor.  Returns a cursor from the datbase

-	 *

-	 * @access  public

-	 * @return  cursor id

-	 */

-	function get_cursor()

-	{

-		$this->curs_id = ocinewcursor($this->conn_id);

-		return $this->curs_id;

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Stored Procedure.  Executes a stored procedure

-	 *

-	 * @access  public

-	 * @param   package	 package stored procedure is in

-	 * @param   procedure   stored procedure to execute

-	 * @param   params	  array of parameters

-	 * @return  array

-	 *

-	 * params array keys

-	 *

-	 * KEY	  OPTIONAL	NOTES

-	 * name		no		the name of the parameter should be in :<param_name> format

-	 * value	no		the value of the parameter.  If this is an OUT or IN OUT parameter,

-	 *					this should be a reference to a variable

-	 * type		yes		the type of the parameter

-	 * length	yes		the max size of the parameter

-	 */

-	function stored_procedure($package, $procedure, $params)

-	{

-		if ($package == '' OR $procedure == '' OR ! is_array($params))

-		{

-			if ($this->db_debug)

-			{

-				log_message('error', 'Invalid query: '.$package.'.'.$procedure);

-				return $this->display_error('db_invalid_query');

-			}

-			return FALSE;

-		}

-		

-		// build the query string

-		$sql = "begin $package.$procedure(";

-

-		$have_cursor = FALSE;

-		foreach($params as $param)

-		{

-			$sql .= $param['name'] . ",";

-			

-			if (array_key_exists('type', $param) && ($param['type'] == OCI_B_CURSOR))

-			{

-				$have_cursor = TRUE;

-			}

-		}

-		$sql = trim($sql, ",") . "); end;";

-				

-		$this->stmt_id = FALSE;

-		$this->_set_stmt_id($sql);

-		$this->_bind_params($params);

-		$this->query($sql, FALSE, $have_cursor);

-	}

-	

-	// --------------------------------------------------------------------

-

-	/**

-	 * Bind parameters

-	 *

-	 * @access  private

-	 * @return  none

-	 */

-	function _bind_params($params)

-	{

-		if ( ! is_array($params) OR ! is_resource($this->stmt_id))

-		{

-			return;

-		}

-		

-		foreach ($params as $param)

-		{

- 			foreach (array('name', 'value', 'type', 'length') as $val)

-			{

-				if ( ! isset($param[$val]))

-				{

-					$param[$val] = '';

-				}

-			}

-

-			ocibindbyname($this->stmt_id, $param['name'], $param['value'], $param['length'], $param['type']);

-		}

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Begin Transaction

-	 *

-	 * @access	public

-	 * @return	bool		

-	 */	

-	function trans_begin($test_mode = FALSE)

-	{

-		if ( ! $this->trans_enabled)

-		{

-			return TRUE;

-		}

-		

-		// When transactions are nested we only begin/commit/rollback the outermost ones

-		if ($this->_trans_depth > 0)

-		{

-			return TRUE;

-		}

-		

-		// Reset the transaction failure flag.

-		// If the $test_mode flag is set to TRUE transactions will be rolled back

-		// even if the queries produce a successful result.

-		$this->_trans_failure = ($test_mode === TRUE) ? TRUE : FALSE;

-		

-		$this->_commit = OCI_DEFAULT;

-		return TRUE;

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Commit Transaction

-	 *

-	 * @access	public

-	 * @return	bool		

-	 */	

-	function trans_commit()

-	{

-		if ( ! $this->trans_enabled)

-		{

-			return TRUE;

-		}

-

-		// When transactions are nested we only begin/commit/rollback the outermost ones

-		if ($this->_trans_depth > 0)

-		{

-			return TRUE;

-		}

-

-		$ret = OCIcommit($this->conn_id);

-		$this->_commit = OCI_COMMIT_ON_SUCCESS;

-		return $ret;

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Rollback Transaction

-	 *

-	 * @access	public

-	 * @return	bool		

-	 */	

-	function trans_rollback()

-	{

-		if ( ! $this->trans_enabled)

-		{

-			return TRUE;

-		}

-

-		// When transactions are nested we only begin/commit/rollback the outermost ones

-		if ($this->_trans_depth > 0)

-		{

-			return TRUE;

-		}

-

-		$ret = OCIrollback($this->conn_id);

-		$this->_commit = OCI_COMMIT_ON_SUCCESS;

-		return $ret;

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Escape String

-	 *

-	 * @access  public

-	 * @param   string

-	 * @return  string

-	 */

-	function escape_str($str)

-	{

-		// Access the CI object

-		$CI =& get_instance();

-

-		return $CI->_remove_invisible_characters($str);

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Affected Rows

-	 *

-	 * @access  public

-	 * @return  integer

-	 */

-	function affected_rows()

-	{

-		return @ocirowcount($this->stmt_id);

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Insert ID

-	 *

-	 * @access  public

-	 * @return  integer

-	 */

-	function insert_id()

-	{

-		// not supported in oracle

-		return $this->display_error('db_unsupported_function');

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * "Count All" query

-	 *

-	 * Generates a platform-specific query string that counts all records in

-	 * the specified database

-	 *

-	 * @access  public

-	 * @param   string

-	 * @return  string

-	 */

-	function count_all($table = '')

-	{

-		if ($table == '')

-			return '0';

-

-		$query = $this->query($this->_count_string . $this->_protect_identifiers('numrows'). " FROM " . $this->_protect_identifiers($table, TRUE, NULL, FALSE));

-

-		if ($query == FALSE)

-			{

-			return 0;

-			}

-

-		$row = $query->row();

-		return $row->NUMROWS;

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Show table query

-	 *

-	 * Generates a platform-specific query string so that the table names can be fetched

-	 *

-	 * @access  private

-	 * @param	boolean

-	 * @return  string

-	 */

-	function _list_tables($prefix_limit = FALSE)

-	{

-		$sql = "SELECT TABLE_NAME FROM ALL_TABLES";

-

-		if ($prefix_limit !== FALSE AND $this->dbprefix != '')

-		{

-			$sql .= " WHERE TABLE_NAME LIKE '".$this->dbprefix."%'";

-		}

-		

-		return $sql;

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Show column query

-	 *

-	 * Generates a platform-specific query string so that the column names can be fetched

-	 *

-	 * @access  public

-	 * @param   string  the table name

-	 * @return  string

-	 */

-	function _list_columns($table = '')

-	{

-		return "SELECT COLUMN_NAME FROM all_tab_columns WHERE table_name = '$table'";

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Field data query

-	 *

-	 * Generates a platform-specific query so that the column data can be retrieved

-	 *

-	 * @access  public

-	 * @param   string  the table name

-	 * @return  object

-	 */

-	function _field_data($table)

-	{

-		return "SELECT * FROM ".$table." where rownum = 1";

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * The error message string

-	 *

-	 * @access  private

-	 * @return  string

-	 */

-	function _error_message()

-	{

-		$error = ocierror($this->conn_id);

-		return $error['message'];

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * The error message number

-	 *

-	 * @access  private

-	 * @return  integer

-	 */

-	function _error_number()

-	{

-		$error = ocierror($this->conn_id);

-		return $error['code'];

-	}

-	

-	// --------------------------------------------------------------------

-

-	/**

-	 * Escape the SQL Identifiers

-	 *

-	 * This function escapes column and table names

-	 *

-	 * @access	private

-	 * @param	string

-	 * @return	string

-	 */

-	function _escape_identifiers($item)

-	{

-		if ($this->_escape_char == '')

-		{

-			return $item;

-		}

-

-		foreach ($this->_reserved_identifiers as $id)

-		{

-			if (strpos($item, '.'.$id) !== FALSE)

-			{

-				$str = $this->_escape_char. str_replace('.', $this->_escape_char.'.', $item);  

-				

-				// remove duplicates if the user already included the escape

-				return preg_replace('/['.$this->_escape_char.']+/', $this->_escape_char, $str);

-			}		

-		}

-	

-		if (strpos($item, '.') !== FALSE)

-		{

-			$str = $this->_escape_char.str_replace('.', $this->_escape_char.'.'.$this->_escape_char, $item).$this->_escape_char;			

-		}

-		else

-		{

-			$str = $this->_escape_char.$item.$this->_escape_char;

-		}

-		

-		// remove duplicates if the user already included the escape

-		return preg_replace('/['.$this->_escape_char.']+/', $this->_escape_char, $str);

-	}

-	

-	// --------------------------------------------------------------------

-

-	/**

-	 * From Tables

-	 *

-	 * This function implicitly groups FROM tables so there is no confusion

-	 * about operator precedence in harmony with SQL standards

-	 *

-	 * @access	public

-	 * @param	type

-	 * @return	type

-	 */

-	function _from_tables($tables)

-	{

-		if ( ! is_array($tables))

-		{

-			$tables = array($tables);

-		}

-		

-		return implode(', ', $tables);

-	}

-

-	// --------------------------------------------------------------------

-	

-	/**

-	 * Insert statement

-	 *

-	 * Generates a platform-specific insert string from the supplied data

-	 *

-	 * @access  public

-	 * @param   string  the table name

-	 * @param   array   the insert keys

-	 * @param   array   the insert values

-	 * @return  string

-	 */

-	function _insert($table, $keys, $values)

-	{

-	return "INSERT INTO ".$table." (".implode(', ', $keys).") VALUES (".implode(', ', $values).")";

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Update statement

-	 *

-	 * Generates a platform-specific update string from the supplied data

-	 *

-	 * @access	public

-	 * @param	string	the table name

-	 * @param	array	the update data

-	 * @param	array	the where clause

-	 * @param	array	the orderby clause

-	 * @param	array	the limit clause

-	 * @return	string

-	 */

-	function _update($table, $values, $where, $orderby = array(), $limit = FALSE)

-	{

-		foreach($values as $key => $val)

-		{

-			$valstr[] = $key." = ".$val;

-		}

-		

-		$limit = ( ! $limit) ? '' : ' LIMIT '.$limit;

-		

-		$orderby = (count($orderby) >= 1)?' ORDER BY '.implode(", ", $orderby):'';

-	

-		$sql = "UPDATE ".$table." SET ".implode(', ', $valstr);

-

-		$sql .= ($where != '' AND count($where) >=1) ? " WHERE ".implode(" ", $where) : '';

-

-		$sql .= $orderby.$limit;

-		

-		return $sql;

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Truncate statement

-	 *

-	 * Generates a platform-specific truncate string from the supplied data

-	 * If the database does not support the truncate() command

-	 * This function maps to "DELETE FROM table"

-	 *

-	 * @access	public

-	 * @param	string	the table name

-	 * @return	string

-	 */	

-	function _truncate($table)

-	{

-		return "TRUNCATE TABLE ".$table;

-	}

-	

-	// --------------------------------------------------------------------

-

-	/**

-	 * Delete statement

-	 *

-	 * Generates a platform-specific delete string from the supplied data

-	 *

-	 * @access	public

-	 * @param	string	the table name

-	 * @param	array	the where clause

-	 * @param	string	the limit clause

-	 * @return	string

-	 */	

-	function _delete($table, $where = array(), $like = array(), $limit = FALSE)

-	{

-		$conditions = '';

-

-		if (count($where) > 0 OR count($like) > 0)

-		{

-			$conditions = "\nWHERE ";

-			$conditions .= implode("\n", $this->ar_where);

-

-			if (count($where) > 0 && count($like) > 0)

-			{

-				$conditions .= " AND ";

-			}

-			$conditions .= implode("\n", $like);

-		}

-

-		$limit = ( ! $limit) ? '' : ' LIMIT '.$limit;

-	

-		return "DELETE FROM ".$table.$conditions.$limit;

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Limit string

-	 *

-	 * Generates a platform-specific LIMIT clause

-	 *

-	 * @access  public

-	 * @param   string  the sql query string

-	 * @param   integer the number of rows to limit the query to

-	 * @param   integer the offset value

-	 * @return  string

-	 */

-	function _limit($sql, $limit, $offset)

-	{

-		$limit = $offset + $limit;

-		$newsql = "SELECT * FROM (select inner_query.*, rownum rnum FROM ($sql) inner_query WHERE rownum < $limit)";

-

-		if ($offset != 0)

-		{

-			$newsql .= " WHERE rnum >= $offset";

-		}

-

-		// remember that we used limits

-		$this->limit_used = TRUE;

-

-		return $newsql;

-	}	

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Close DB Connection

-	 *

-	 * @access  public

-	 * @param   resource

-	 * @return  void

-	 */

-	function _close($conn_id)

-	{

-		@ocilogoff($conn_id);

-	}

-

-

-}

-

-

-

-/* End of file oci8_driver.php */

+<?php  if ( ! defined('BASEPATH')) exit('No direct script access allowed');
+/**
+ * CodeIgniter
+ *
+ * An open source application development framework for PHP 4.3.2 or newer
+ *
+ * @package	 	CodeIgniter
+ * @author	  	ExpressionEngine Dev Team
+ * @copyright   Copyright (c) 2008, EllisLab, Inc.
+ * @license	 	http://codeigniter.com/user_guide/license.html
+ * @link		http://codeigniter.com
+ * @since	   	Version 1.0
+ * @filesource
+ */
+
+// ------------------------------------------------------------------------
+
+/**
+ * oci8 Database Adapter Class
+ *
+ * Note: _DB is an extender class that the app controller
+ * creates dynamically based on whether the active record
+ * class is being used or not.
+ *
+ * @package	 	CodeIgniter
+ * @subpackage  Drivers
+ * @category	Database
+ * @author	  	ExpressionEngine Dev Team
+ * @link		http://codeigniter.com/user_guide/database/
+ */
+
+/**
+ * oci8 Database Adapter Class
+ *
+ * This is a modification of the DB_driver class to
+ * permit access to oracle databases
+ *
+ * NOTE: this uses the PHP 4 oci methods
+ *
+ * @author	  Kelly McArdle
+ *
+ */
+
+class CI_DB_oci8_driver extends CI_DB {
+
+	var $dbdriver = 'oci8';
+	
+	// The character used for excaping
+	var $_escape_char = '"';
+
+	/**
+	 * The syntax to count rows is slightly different across different
+	 * database engines, so this string appears in each driver and is
+	 * used for the count_all() and count_all_results() functions.
+	 */
+	var $_count_string = "SELECT COUNT(1) AS ";
+	var $_random_keyword = ' ASC'; // not currently supported
+
+	// Set "auto commit" by default
+	var $_commit = OCI_COMMIT_ON_SUCCESS;
+
+	// need to track statement id and cursor id
+	var $stmt_id;
+	var $curs_id;
+
+	// if we use a limit, we will add a field that will
+	// throw off num_fields later
+	var $limit_used;
+
+	/**
+	 * Non-persistent database connection
+	 *
+	 * @access  private called by the base class
+	 * @return  resource
+	 */
+	function db_connect()
+	{
+		return @ocilogon($this->username, $this->password, $this->hostname);
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Persistent database connection
+	 *
+	 * @access  private called by the base class
+	 * @return  resource
+	 */
+	function db_pconnect()
+	{
+		return @ociplogon($this->username, $this->password, $this->hostname);
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Select the database
+	 *
+	 * @access  private called by the base class
+	 * @return  resource
+	 */
+	function db_select()
+	{
+		return TRUE;
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Set client character set
+	 *
+	 * @access	public
+	 * @param	string
+	 * @param	string
+	 * @return	resource
+	 */
+	function db_set_charset($charset, $collation)
+	{
+		// @todo - add support if needed
+		return TRUE;
+	}
+
+	// --------------------------------------------------------------------
+	
+	/**
+	 * Version number query string
+	 *
+	 * @access  public
+	 * @return  string
+	 */
+	function _version()
+	{
+		return ociserverversion($this->conn_id);
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Execute the query
+	 *
+	 * @access  private called by the base class
+	 * @param   string  an SQL query
+	 * @return  resource
+	 */
+	function _execute($sql)
+	{
+		// oracle must parse the query before it is run. All of the actions with
+		// the query are based on the statement id returned by ociparse
+		$this->stmt_id = FALSE;
+		$this->_set_stmt_id($sql);
+		ocisetprefetch($this->stmt_id, 1000);
+		return @ociexecute($this->stmt_id, $this->_commit);
+	}
+
+	/**
+	 * Generate a statement ID
+	 *
+	 * @access  private
+	 * @param   string  an SQL query
+	 * @return  none
+	 */
+	function _set_stmt_id($sql)
+	{
+		if ( ! is_resource($this->stmt_id))
+		{
+			$this->stmt_id = ociparse($this->conn_id, $this->_prep_query($sql));
+		}
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Prep the query
+	 *
+	 * If needed, each database adapter can prep the query string
+	 *
+	 * @access  private called by execute()
+	 * @param   string  an SQL query
+	 * @return  string
+	 */
+	function _prep_query($sql)
+	{
+		return $sql;
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * getCursor.  Returns a cursor from the datbase
+	 *
+	 * @access  public
+	 * @return  cursor id
+	 */
+	function get_cursor()
+	{
+		$this->curs_id = ocinewcursor($this->conn_id);
+		return $this->curs_id;
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Stored Procedure.  Executes a stored procedure
+	 *
+	 * @access  public
+	 * @param   package	 package stored procedure is in
+	 * @param   procedure   stored procedure to execute
+	 * @param   params	  array of parameters
+	 * @return  array
+	 *
+	 * params array keys
+	 *
+	 * KEY	  OPTIONAL	NOTES
+	 * name		no		the name of the parameter should be in :<param_name> format
+	 * value	no		the value of the parameter.  If this is an OUT or IN OUT parameter,
+	 *					this should be a reference to a variable
+	 * type		yes		the type of the parameter
+	 * length	yes		the max size of the parameter
+	 */
+	function stored_procedure($package, $procedure, $params)
+	{
+		if ($package == '' OR $procedure == '' OR ! is_array($params))
+		{
+			if ($this->db_debug)
+			{
+				log_message('error', 'Invalid query: '.$package.'.'.$procedure);
+				return $this->display_error('db_invalid_query');
+			}
+			return FALSE;
+		}
+		
+		// build the query string
+		$sql = "begin $package.$procedure(";
+
+		$have_cursor = FALSE;
+		foreach($params as $param)
+		{
+			$sql .= $param['name'] . ",";
+			
+			if (array_key_exists('type', $param) && ($param['type'] == OCI_B_CURSOR))
+			{
+				$have_cursor = TRUE;
+			}
+		}
+		$sql = trim($sql, ",") . "); end;";
+				
+		$this->stmt_id = FALSE;
+		$this->_set_stmt_id($sql);
+		$this->_bind_params($params);
+		$this->query($sql, FALSE, $have_cursor);
+	}
+	
+	// --------------------------------------------------------------------
+
+	/**
+	 * Bind parameters
+	 *
+	 * @access  private
+	 * @return  none
+	 */
+	function _bind_params($params)
+	{
+		if ( ! is_array($params) OR ! is_resource($this->stmt_id))
+		{
+			return;
+		}
+		
+		foreach ($params as $param)
+		{
+ 			foreach (array('name', 'value', 'type', 'length') as $val)
+			{
+				if ( ! isset($param[$val]))
+				{
+					$param[$val] = '';
+				}
+			}
+
+			ocibindbyname($this->stmt_id, $param['name'], $param['value'], $param['length'], $param['type']);
+		}
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Begin Transaction
+	 *
+	 * @access	public
+	 * @return	bool		
+	 */	
+	function trans_begin($test_mode = FALSE)
+	{
+		if ( ! $this->trans_enabled)
+		{
+			return TRUE;
+		}
+		
+		// When transactions are nested we only begin/commit/rollback the outermost ones
+		if ($this->_trans_depth > 0)
+		{
+			return TRUE;
+		}
+		
+		// Reset the transaction failure flag.
+		// If the $test_mode flag is set to TRUE transactions will be rolled back
+		// even if the queries produce a successful result.
+		$this->_trans_failure = ($test_mode === TRUE) ? TRUE : FALSE;
+		
+		$this->_commit = OCI_DEFAULT;
+		return TRUE;
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Commit Transaction
+	 *
+	 * @access	public
+	 * @return	bool		
+	 */	
+	function trans_commit()
+	{
+		if ( ! $this->trans_enabled)
+		{
+			return TRUE;
+		}
+
+		// When transactions are nested we only begin/commit/rollback the outermost ones
+		if ($this->_trans_depth > 0)
+		{
+			return TRUE;
+		}
+
+		$ret = OCIcommit($this->conn_id);
+		$this->_commit = OCI_COMMIT_ON_SUCCESS;
+		return $ret;
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Rollback Transaction
+	 *
+	 * @access	public
+	 * @return	bool		
+	 */	
+	function trans_rollback()
+	{
+		if ( ! $this->trans_enabled)
+		{
+			return TRUE;
+		}
+
+		// When transactions are nested we only begin/commit/rollback the outermost ones
+		if ($this->_trans_depth > 0)
+		{
+			return TRUE;
+		}
+
+		$ret = OCIrollback($this->conn_id);
+		$this->_commit = OCI_COMMIT_ON_SUCCESS;
+		return $ret;
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Escape String
+	 *
+	 * @access  public
+	 * @param   string
+	 * @return  string
+	 */
+	function escape_str($str)
+	{
+		// Access the CI object
+		$CI =& get_instance();
+
+		return $CI->_remove_invisible_characters($str);
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Affected Rows
+	 *
+	 * @access  public
+	 * @return  integer
+	 */
+	function affected_rows()
+	{
+		return @ocirowcount($this->stmt_id);
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Insert ID
+	 *
+	 * @access  public
+	 * @return  integer
+	 */
+	function insert_id()
+	{
+		// not supported in oracle
+		return $this->display_error('db_unsupported_function');
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * "Count All" query
+	 *
+	 * Generates a platform-specific query string that counts all records in
+	 * the specified database
+	 *
+	 * @access  public
+	 * @param   string
+	 * @return  string
+	 */
+	function count_all($table = '')
+	{
+		if ($table == '')
+			return '0';
+
+		$query = $this->query($this->_count_string . $this->_protect_identifiers('numrows'). " FROM " . $this->_protect_identifiers($table, TRUE, NULL, FALSE));
+
+		if ($query == FALSE)
+			{
+			return 0;
+			}
+
+		$row = $query->row();
+		return $row->NUMROWS;
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Show table query
+	 *
+	 * Generates a platform-specific query string so that the table names can be fetched
+	 *
+	 * @access  private
+	 * @param	boolean
+	 * @return  string
+	 */
+	function _list_tables($prefix_limit = FALSE)
+	{
+		$sql = "SELECT TABLE_NAME FROM ALL_TABLES";
+
+		if ($prefix_limit !== FALSE AND $this->dbprefix != '')
+		{
+			$sql .= " WHERE TABLE_NAME LIKE '".$this->dbprefix."%'";
+		}
+		
+		return $sql;
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Show column query
+	 *
+	 * Generates a platform-specific query string so that the column names can be fetched
+	 *
+	 * @access  public
+	 * @param   string  the table name
+	 * @return  string
+	 */
+	function _list_columns($table = '')
+	{
+		return "SELECT COLUMN_NAME FROM all_tab_columns WHERE table_name = '$table'";
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Field data query
+	 *
+	 * Generates a platform-specific query so that the column data can be retrieved
+	 *
+	 * @access  public
+	 * @param   string  the table name
+	 * @return  object
+	 */
+	function _field_data($table)
+	{
+		return "SELECT * FROM ".$table." where rownum = 1";
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * The error message string
+	 *
+	 * @access  private
+	 * @return  string
+	 */
+	function _error_message()
+	{
+		$error = ocierror($this->conn_id);
+		return $error['message'];
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * The error message number
+	 *
+	 * @access  private
+	 * @return  integer
+	 */
+	function _error_number()
+	{
+		$error = ocierror($this->conn_id);
+		return $error['code'];
+	}
+	
+	// --------------------------------------------------------------------
+
+	/**
+	 * Escape the SQL Identifiers
+	 *
+	 * This function escapes column and table names
+	 *
+	 * @access	private
+	 * @param	string
+	 * @return	string
+	 */
+	function _escape_identifiers($item)
+	{
+		if ($this->_escape_char == '')
+		{
+			return $item;
+		}
+
+		foreach ($this->_reserved_identifiers as $id)
+		{
+			if (strpos($item, '.'.$id) !== FALSE)
+			{
+				$str = $this->_escape_char. str_replace('.', $this->_escape_char.'.', $item);  
+				
+				// remove duplicates if the user already included the escape
+				return preg_replace('/['.$this->_escape_char.']+/', $this->_escape_char, $str);
+			}		
+		}
+	
+		if (strpos($item, '.') !== FALSE)
+		{
+			$str = $this->_escape_char.str_replace('.', $this->_escape_char.'.'.$this->_escape_char, $item).$this->_escape_char;			
+		}
+		else
+		{
+			$str = $this->_escape_char.$item.$this->_escape_char;
+		}
+		
+		// remove duplicates if the user already included the escape
+		return preg_replace('/['.$this->_escape_char.']+/', $this->_escape_char, $str);
+	}
+	
+	// --------------------------------------------------------------------
+
+	/**
+	 * From Tables
+	 *
+	 * This function implicitly groups FROM tables so there is no confusion
+	 * about operator precedence in harmony with SQL standards
+	 *
+	 * @access	public
+	 * @param	type
+	 * @return	type
+	 */
+	function _from_tables($tables)
+	{
+		if ( ! is_array($tables))
+		{
+			$tables = array($tables);
+		}
+		
+		return implode(', ', $tables);
+	}
+
+	// --------------------------------------------------------------------
+	
+	/**
+	 * Insert statement
+	 *
+	 * Generates a platform-specific insert string from the supplied data
+	 *
+	 * @access  public
+	 * @param   string  the table name
+	 * @param   array   the insert keys
+	 * @param   array   the insert values
+	 * @return  string
+	 */
+	function _insert($table, $keys, $values)
+	{
+	return "INSERT INTO ".$table." (".implode(', ', $keys).") VALUES (".implode(', ', $values).")";
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Update statement
+	 *
+	 * Generates a platform-specific update string from the supplied data
+	 *
+	 * @access	public
+	 * @param	string	the table name
+	 * @param	array	the update data
+	 * @param	array	the where clause
+	 * @param	array	the orderby clause
+	 * @param	array	the limit clause
+	 * @return	string
+	 */
+	function _update($table, $values, $where, $orderby = array(), $limit = FALSE)
+	{
+		foreach($values as $key => $val)
+		{
+			$valstr[] = $key." = ".$val;
+		}
+		
+		$limit = ( ! $limit) ? '' : ' LIMIT '.$limit;
+		
+		$orderby = (count($orderby) >= 1)?' ORDER BY '.implode(", ", $orderby):'';
+	
+		$sql = "UPDATE ".$table." SET ".implode(', ', $valstr);
+
+		$sql .= ($where != '' AND count($where) >=1) ? " WHERE ".implode(" ", $where) : '';
+
+		$sql .= $orderby.$limit;
+		
+		return $sql;
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Truncate statement
+	 *
+	 * Generates a platform-specific truncate string from the supplied data
+	 * If the database does not support the truncate() command
+	 * This function maps to "DELETE FROM table"
+	 *
+	 * @access	public
+	 * @param	string	the table name
+	 * @return	string
+	 */	
+	function _truncate($table)
+	{
+		return "TRUNCATE TABLE ".$table;
+	}
+	
+	// --------------------------------------------------------------------
+
+	/**
+	 * Delete statement
+	 *
+	 * Generates a platform-specific delete string from the supplied data
+	 *
+	 * @access	public
+	 * @param	string	the table name
+	 * @param	array	the where clause
+	 * @param	string	the limit clause
+	 * @return	string
+	 */	
+	function _delete($table, $where = array(), $like = array(), $limit = FALSE)
+	{
+		$conditions = '';
+
+		if (count($where) > 0 OR count($like) > 0)
+		{
+			$conditions = "\nWHERE ";
+			$conditions .= implode("\n", $this->ar_where);
+
+			if (count($where) > 0 && count($like) > 0)
+			{
+				$conditions .= " AND ";
+			}
+			$conditions .= implode("\n", $like);
+		}
+
+		$limit = ( ! $limit) ? '' : ' LIMIT '.$limit;
+	
+		return "DELETE FROM ".$table.$conditions.$limit;
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Limit string
+	 *
+	 * Generates a platform-specific LIMIT clause
+	 *
+	 * @access  public
+	 * @param   string  the sql query string
+	 * @param   integer the number of rows to limit the query to
+	 * @param   integer the offset value
+	 * @return  string
+	 */
+	function _limit($sql, $limit, $offset)
+	{
+		$limit = $offset + $limit;
+		$newsql = "SELECT * FROM (select inner_query.*, rownum rnum FROM ($sql) inner_query WHERE rownum < $limit)";
+
+		if ($offset != 0)
+		{
+			$newsql .= " WHERE rnum >= $offset";
+		}
+
+		// remember that we used limits
+		$this->limit_used = TRUE;
+
+		return $newsql;
+	}	
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Close DB Connection
+	 *
+	 * @access  public
+	 * @param   resource
+	 * @return  void
+	 */
+	function _close($conn_id)
+	{
+		@ocilogoff($conn_id);
+	}
+
+
+}
+
+
+
+/* End of file oci8_driver.php */
 /* Location: ./system/database/drivers/oci8/oci8_driver.php */
\ No newline at end of file
diff --git a/system/database/drivers/oci8/oci8_forge.php b/system/database/drivers/oci8/oci8_forge.php
index 4b073d0..bbc11f3 100644
--- a/system/database/drivers/oci8/oci8_forge.php
+++ b/system/database/drivers/oci8/oci8_forge.php
@@ -1,248 +1,248 @@
-<?php  if ( ! defined('BASEPATH')) exit('No direct script access allowed');

-/**

- * CodeIgniter

- *

- * An open source application development framework for PHP 4.3.2 or newer

- *

- * @package		CodeIgniter

- * @author		ExpressionEngine Dev Team

- * @copyright	Copyright (c) 2008, EllisLab, Inc.

- * @license		http://codeigniter.com/user_guide/license.html

- * @link		http://codeigniter.com

- * @since		Version 1.0

- * @filesource

- */

-

-// ------------------------------------------------------------------------

-

-/**

- * Oracle Forge Class

- *

- * @category	Database

- * @author		ExpressionEngine Dev Team

- * @link		http://codeigniter.com/user_guide/database/

- */

-class CI_DB_oci8_forge extends CI_DB_forge {

-

-	/**

-	 * Create database

-	 *

-	 * @access	public

-	 * @param	string	the database name

-	 * @return	bool

-	 */

-	function _create_database($name)

-	{

-		return FALSE;

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Drop database

-	 *

-	 * @access	private

-	 * @param	string	the database name

-	 * @return	bool

-	 */

-	function _drop_database($name)

-	{

-		return FALSE;

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Create Table

-	 *

-	 * @access	private

-	 * @param	string	the table name

-	 * @param	array	the fields

-	 * @param	mixed	primary key(s)

-	 * @param	mixed	key(s)

-	 * @param	boolean	should 'IF NOT EXISTS' be added to the SQL

-	 * @return	bool

-	 */

-	function _create_table($table, $fields, $primary_keys, $keys, $if_not_exists)

-	{

-		$sql = 'CREATE TABLE ';

-		

-		if ($if_not_exists === TRUE)

-		{

-			$sql .= 'IF NOT EXISTS ';

-		}

-		

-		$sql .= $this->db->_escape_identifiers($table)." (";

-		$current_field_count = 0;

-

-		foreach ($fields as $field=>$attributes)

-		{

-			// Numeric field names aren't allowed in databases, so if the key is

-			// numeric, we know it was assigned by PHP and the developer manually

-			// entered the field information, so we'll simply add it to the list

-			if (is_numeric($field))

-			{

-				$sql .= "\n\t$attributes";

-			}

-			else

-			{

-				$attributes = array_change_key_case($attributes, CASE_UPPER);

-				

-				$sql .= "\n\t".$this->db->_protect_identifiers($field);

-				

-				$sql .=  ' '.$attributes['TYPE'];

-	

-				if (array_key_exists('CONSTRAINT', $attributes))

-				{

-					$sql .= '('.$attributes['CONSTRAINT'].')';

-				}

-	

-				if (array_key_exists('UNSIGNED', $attributes) && $attributes['UNSIGNED'] === TRUE)

-				{

-					$sql .= ' UNSIGNED';

-				}

-	

-				if (array_key_exists('DEFAULT', $attributes))

-				{

-					$sql .= ' DEFAULT \''.$attributes['DEFAULT'].'\'';

-				}

-	

-				if (array_key_exists('NULL', $attributes) && $attributes['NULL'] === TRUE)

-				{

-					$sql .= ' NULL';

-				}

-				else

-				{

-					$sql .= ' NOT NULL';			

-				}

-	

-				if (array_key_exists('AUTO_INCREMENT', $attributes) && $attributes['AUTO_INCREMENT'] === TRUE)

-				{

-					$sql .= ' AUTO_INCREMENT';

-				}

-			}

-			

-			// don't add a comma on the end of the last field

-			if (++$current_field_count < count($fields))

-			{

-				$sql .= ',';

-			}

-		}

-

-		if (count($primary_keys) > 0)

-		{

-			$primary_keys = $this->db->_protect_identifiers($primary_keys);

-			$sql .= ",\n\tPRIMARY KEY (" . implode(', ', $primary_keys) . ")";

-		}

-

-		if (is_array($keys) && count($keys) > 0)

-		{

-			foreach ($keys as $key)

-			{

-				if (is_array($key))

-				{

-					$key = $this->db->_protect_identifiers($key);	

-				}

-				else

-				{

-					$key = array($this->db->_protect_identifiers($key));

-				}

-				

-				$sql .= ",\n\tUNIQUE COLUMNS (" . implode(', ', $key) . ")";

-			}

-		}

-		

-		$sql .= "\n)";

-

-		return $sql;

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Drop Table

-	 *

-	 * @access	private

-	 * @return	bool

-	 */

-	function _drop_table($table)

-	{

-		return FALSE;

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Alter table query

-	 *

-	 * Generates a platform-specific query so that a table can be altered

-	 * Called by add_column(), drop_column(), and column_alter(),

-	 *

-	 * @access	private

-	 * @param	string	the ALTER type (ADD, DROP, CHANGE)

-	 * @param	string	the column name

-	 * @param	string	the table name

-	 * @param	string	the column definition

-	 * @param	string	the default value

-	 * @param	boolean	should 'NOT NULL' be added

-	 * @param	string	the field after which we should add the new field

-	 * @return	object

-	 */

-	function _alter_table($alter_type, $table, $column_name, $column_definition = '', $default_value = '', $null = '', $after_field = '')

-	{

-		$sql = 'ALTER TABLE '.$this->db->_protect_identifiers($table)." $alter_type ".$this->db->_protect_identifiers($column_name);

-

-		// DROP has everything it needs now.

-		if ($alter_type == 'DROP')

-		{

-			return $sql;

-		}

-

-		$sql .= " $column_definition";

-

-		if ($default_value != '')

-		{

-			$sql .= " DEFAULT \"$default_value\"";

-		}

-

-		if ($null === NULL)

-		{

-			$sql .= ' NULL';

-		}

-		else

-		{

-			$sql .= ' NOT NULL';

-		}

-

-		if ($after_field != '')

-		{

-			$sql .= ' AFTER ' . $this->db->_protect_identifiers($after_field);

-		}

-		

-		return $sql;

-		

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Rename a table

-	 *

-	 * Generates a platform-specific query so that a table can be renamed

-	 *

-	 * @access	private

-	 * @param	string	the old table name

-	 * @param	string	the new table name

-	 * @return	string

-	 */

-	function _rename_table($table_name, $new_table_name)

-	{

-		$sql = 'ALTER TABLE '.$this->db->_protect_identifiers($table_name)." RENAME TO ".$this->db->_protect_identifiers($new_table_name);

-		return $sql;

-	}

-

-

-}

-

-/* End of file oci8_forge.php */

+<?php  if ( ! defined('BASEPATH')) exit('No direct script access allowed');
+/**
+ * CodeIgniter
+ *
+ * An open source application development framework for PHP 4.3.2 or newer
+ *
+ * @package		CodeIgniter
+ * @author		ExpressionEngine Dev Team
+ * @copyright	Copyright (c) 2008, EllisLab, Inc.
+ * @license		http://codeigniter.com/user_guide/license.html
+ * @link		http://codeigniter.com
+ * @since		Version 1.0
+ * @filesource
+ */
+
+// ------------------------------------------------------------------------
+
+/**
+ * Oracle Forge Class
+ *
+ * @category	Database
+ * @author		ExpressionEngine Dev Team
+ * @link		http://codeigniter.com/user_guide/database/
+ */
+class CI_DB_oci8_forge extends CI_DB_forge {
+
+	/**
+	 * Create database
+	 *
+	 * @access	public
+	 * @param	string	the database name
+	 * @return	bool
+	 */
+	function _create_database($name)
+	{
+		return FALSE;
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Drop database
+	 *
+	 * @access	private
+	 * @param	string	the database name
+	 * @return	bool
+	 */
+	function _drop_database($name)
+	{
+		return FALSE;
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Create Table
+	 *
+	 * @access	private
+	 * @param	string	the table name
+	 * @param	array	the fields
+	 * @param	mixed	primary key(s)
+	 * @param	mixed	key(s)
+	 * @param	boolean	should 'IF NOT EXISTS' be added to the SQL
+	 * @return	bool
+	 */
+	function _create_table($table, $fields, $primary_keys, $keys, $if_not_exists)
+	{
+		$sql = 'CREATE TABLE ';
+		
+		if ($if_not_exists === TRUE)
+		{
+			$sql .= 'IF NOT EXISTS ';
+		}
+		
+		$sql .= $this->db->_escape_identifiers($table)." (";
+		$current_field_count = 0;
+
+		foreach ($fields as $field=>$attributes)
+		{
+			// Numeric field names aren't allowed in databases, so if the key is
+			// numeric, we know it was assigned by PHP and the developer manually
+			// entered the field information, so we'll simply add it to the list
+			if (is_numeric($field))
+			{
+				$sql .= "\n\t$attributes";
+			}
+			else
+			{
+				$attributes = array_change_key_case($attributes, CASE_UPPER);
+				
+				$sql .= "\n\t".$this->db->_protect_identifiers($field);
+				
+				$sql .=  ' '.$attributes['TYPE'];
+	
+				if (array_key_exists('CONSTRAINT', $attributes))
+				{
+					$sql .= '('.$attributes['CONSTRAINT'].')';
+				}
+	
+				if (array_key_exists('UNSIGNED', $attributes) && $attributes['UNSIGNED'] === TRUE)
+				{
+					$sql .= ' UNSIGNED';
+				}
+	
+				if (array_key_exists('DEFAULT', $attributes))
+				{
+					$sql .= ' DEFAULT \''.$attributes['DEFAULT'].'\'';
+				}
+	
+				if (array_key_exists('NULL', $attributes) && $attributes['NULL'] === TRUE)
+				{
+					$sql .= ' NULL';
+				}
+				else
+				{
+					$sql .= ' NOT NULL';			
+				}
+	
+				if (array_key_exists('AUTO_INCREMENT', $attributes) && $attributes['AUTO_INCREMENT'] === TRUE)
+				{
+					$sql .= ' AUTO_INCREMENT';
+				}
+			}
+			
+			// don't add a comma on the end of the last field
+			if (++$current_field_count < count($fields))
+			{
+				$sql .= ',';
+			}
+		}
+
+		if (count($primary_keys) > 0)
+		{
+			$primary_keys = $this->db->_protect_identifiers($primary_keys);
+			$sql .= ",\n\tPRIMARY KEY (" . implode(', ', $primary_keys) . ")";
+		}
+
+		if (is_array($keys) && count($keys) > 0)
+		{
+			foreach ($keys as $key)
+			{
+				if (is_array($key))
+				{
+					$key = $this->db->_protect_identifiers($key);	
+				}
+				else
+				{
+					$key = array($this->db->_protect_identifiers($key));
+				}
+				
+				$sql .= ",\n\tUNIQUE COLUMNS (" . implode(', ', $key) . ")";
+			}
+		}
+		
+		$sql .= "\n)";
+
+		return $sql;
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Drop Table
+	 *
+	 * @access	private
+	 * @return	bool
+	 */
+	function _drop_table($table)
+	{
+		return FALSE;
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Alter table query
+	 *
+	 * Generates a platform-specific query so that a table can be altered
+	 * Called by add_column(), drop_column(), and column_alter(),
+	 *
+	 * @access	private
+	 * @param	string	the ALTER type (ADD, DROP, CHANGE)
+	 * @param	string	the column name
+	 * @param	string	the table name
+	 * @param	string	the column definition
+	 * @param	string	the default value
+	 * @param	boolean	should 'NOT NULL' be added
+	 * @param	string	the field after which we should add the new field
+	 * @return	object
+	 */
+	function _alter_table($alter_type, $table, $column_name, $column_definition = '', $default_value = '', $null = '', $after_field = '')
+	{
+		$sql = 'ALTER TABLE '.$this->db->_protect_identifiers($table)." $alter_type ".$this->db->_protect_identifiers($column_name);
+
+		// DROP has everything it needs now.
+		if ($alter_type == 'DROP')
+		{
+			return $sql;
+		}
+
+		$sql .= " $column_definition";
+
+		if ($default_value != '')
+		{
+			$sql .= " DEFAULT \"$default_value\"";
+		}
+
+		if ($null === NULL)
+		{
+			$sql .= ' NULL';
+		}
+		else
+		{
+			$sql .= ' NOT NULL';
+		}
+
+		if ($after_field != '')
+		{
+			$sql .= ' AFTER ' . $this->db->_protect_identifiers($after_field);
+		}
+		
+		return $sql;
+		
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Rename a table
+	 *
+	 * Generates a platform-specific query so that a table can be renamed
+	 *
+	 * @access	private
+	 * @param	string	the old table name
+	 * @param	string	the new table name
+	 * @return	string
+	 */
+	function _rename_table($table_name, $new_table_name)
+	{
+		$sql = 'ALTER TABLE '.$this->db->_protect_identifiers($table_name)." RENAME TO ".$this->db->_protect_identifiers($new_table_name);
+		return $sql;
+	}
+
+
+}
+
+/* End of file oci8_forge.php */
 /* Location: ./system/database/drivers/oci8/oci8_forge.php */
\ No newline at end of file
diff --git a/system/database/drivers/oci8/oci8_result.php b/system/database/drivers/oci8/oci8_result.php
index 4cfbfa4..7d7cd1c 100644
--- a/system/database/drivers/oci8/oci8_result.php
+++ b/system/database/drivers/oci8/oci8_result.php
@@ -1,249 +1,249 @@
-<?php  if ( ! defined('BASEPATH')) exit('No direct script access allowed');

-/**

- * CodeIgniter

- *

- * An open source application development framework for PHP 4.3.2 or newer

- *

- * @package	 	CodeIgniter

- * @author	 	ExpressionEngine Dev Team

- * @copyright   Copyright (c) 2008, EllisLab, Inc.

- * @license	 	http://codeigniter.com/user_guide/license.html

- * @link		http://codeigniter.com

- * @since	   	Version 1.0

- * @filesource

- */

-

-// ------------------------------------------------------------------------

-

-/**

- * oci8 Result Class

- *

- * This class extends the parent result class: CI_DB_result

- *

- * @category	Database

- * @author	 	ExpressionEngine Dev Team

- * @link		http://codeigniter.com/user_guide/database/

- */

-class CI_DB_oci8_result extends CI_DB_result {

-

-	var $stmt_id;

-	var $curs_id;

-	var $limit_used;

-

-	/**

-	 * Number of rows in the result set.

-	 *

-	 * Oracle doesn't have a graceful way to retun the number of rows

-	 * so we have to use what amounts to a hack.

-	 * 

-	 *

-	 * @access  public

-	 * @return  integer

-	 */

-	function num_rows()

-	{

-		$rowcount = count($this->result_array());

-		@ociexecute($this->stmt_id);

-

-		if ($this->curs_id)

-		{

-			@ociexecute($this->curs_id);

-		}

-

-		return $rowcount;

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Number of fields in the result set

-	 *

-	 * @access  public

-	 * @return  integer

-	 */

-	function num_fields()

-	{

-		$count = @ocinumcols($this->stmt_id);

-

-		// if we used a limit we subtract it

-		if ($this->limit_used)

-		{

-			$count = $count - 1;

-		}

-

-		return $count;

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Fetch Field Names

-	 *

-	 * Generates an array of column names

-	 *

-	 * @access	public

-	 * @return	array

-	 */

-	function list_fields()

-	{

-		$field_names = array();

-		$fieldCount = $this->num_fields();

-		for ($c = 1; $c <= $fieldCount; $c++)

-		{

-			$field_names[] = ocicolumnname($this->stmt_id, $c);

-		}

-		return $field_names;

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Field data

-	 *

-	 * Generates an array of objects containing field meta-data

-	 *

-	 * @access  public

-	 * @return  array

-	 */

-	function field_data()

-	{

-		$retval = array();

-		$fieldCount = $this->num_fields();

-		for ($c = 1; $c <= $fieldCount; $c++)

-		{

-			$F			  = new stdClass();

-			$F->name		= ocicolumnname($this->stmt_id, $c);

-			$F->type		= ocicolumntype($this->stmt_id, $c);

-			$F->max_length  = ocicolumnsize($this->stmt_id, $c);

-

-			$retval[] = $F;

-		}

-

-		return $retval;

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Free the result

-	 *

-	 * @return	null

-	 */		

-	function free_result()

-	{

-		if (is_resource($this->result_id))

-		{

-			ocifreestatement($this->result_id);			

-			$this->result_id = FALSE;

-		}

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Result - associative array

-	 *

-	 * Returns the result set as an array

-	 *

-	 * @access  private

-	 * @return  array

-	 */

-	function _fetch_assoc(&$row)

-	{

-		$id = ($this->curs_id) ? $this->curs_id : $this->stmt_id;

-	

-		return ocifetchinto($id, $row, OCI_ASSOC + OCI_RETURN_NULLS);	

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Result - object

-	 *

-	 * Returns the result set as an object

-	 *

-	 * @access  private

-	 * @return  object

-	 */

-	function _fetch_object()

-	{	

-		$result = array();

-

-		// If PHP 5 is being used we can fetch an result object

-		if (function_exists('oci_fetch_object'))

-		{

-			$id = ($this->curs_id) ? $this->curs_id : $this->stmt_id;

-			

-			return @oci_fetch_object($id);

-		}

-		

-		// If PHP 4 is being used we have to build our own result

-		foreach ($this->result_array() as $key => $val)

-		{

-			$obj = new stdClass();

-			if (is_array($val))

-			{

-				foreach ($val as $k => $v)

-				{

-					$obj->$k = $v;

-				}

-			}

-			else

-			{

-				$obj->$key = $val;

-			}

-			

-			$result[] = $obj;

-		}

-

-		return $result;

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Query result.  "array" version.

-	 *

-	 * @access  public

-	 * @return  array

-	 */

-	function result_array()

-	{

-		if (count($this->result_array) > 0)

-		{

-			return $this->result_array;

-		}

-

-		// oracle's fetch functions do not return arrays.

-		// The information is returned in reference parameters

-		$row = NULL;

-		while ($this->_fetch_assoc($row))

-		{

-			$this->result_array[] = $row;

-		}

-

-		return $this->result_array;

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Data Seek

-	 *

-	 * Moves the internal pointer to the desired offset.  We call

-	 * this internally before fetching results to make sure the

-	 * result set starts at zero

-	 *

-	 * @access	private

-	 * @return	array

-	 */

-	function _data_seek($n = 0)

-	{

-		return FALSE; // Not needed

-	}

-

-}

-

-

-/* End of file oci8_result.php */

+<?php  if ( ! defined('BASEPATH')) exit('No direct script access allowed');
+/**
+ * CodeIgniter
+ *
+ * An open source application development framework for PHP 4.3.2 or newer
+ *
+ * @package	 	CodeIgniter
+ * @author	 	ExpressionEngine Dev Team
+ * @copyright   Copyright (c) 2008, EllisLab, Inc.
+ * @license	 	http://codeigniter.com/user_guide/license.html
+ * @link		http://codeigniter.com
+ * @since	   	Version 1.0
+ * @filesource
+ */
+
+// ------------------------------------------------------------------------
+
+/**
+ * oci8 Result Class
+ *
+ * This class extends the parent result class: CI_DB_result
+ *
+ * @category	Database
+ * @author	 	ExpressionEngine Dev Team
+ * @link		http://codeigniter.com/user_guide/database/
+ */
+class CI_DB_oci8_result extends CI_DB_result {
+
+	var $stmt_id;
+	var $curs_id;
+	var $limit_used;
+
+	/**
+	 * Number of rows in the result set.
+	 *
+	 * Oracle doesn't have a graceful way to retun the number of rows
+	 * so we have to use what amounts to a hack.
+	 * 
+	 *
+	 * @access  public
+	 * @return  integer
+	 */
+	function num_rows()
+	{
+		$rowcount = count($this->result_array());
+		@ociexecute($this->stmt_id);
+
+		if ($this->curs_id)
+		{
+			@ociexecute($this->curs_id);
+		}
+
+		return $rowcount;
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Number of fields in the result set
+	 *
+	 * @access  public
+	 * @return  integer
+	 */
+	function num_fields()
+	{
+		$count = @ocinumcols($this->stmt_id);
+
+		// if we used a limit we subtract it
+		if ($this->limit_used)
+		{
+			$count = $count - 1;
+		}
+
+		return $count;
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Fetch Field Names
+	 *
+	 * Generates an array of column names
+	 *
+	 * @access	public
+	 * @return	array
+	 */
+	function list_fields()
+	{
+		$field_names = array();
+		$fieldCount = $this->num_fields();
+		for ($c = 1; $c <= $fieldCount; $c++)
+		{
+			$field_names[] = ocicolumnname($this->stmt_id, $c);
+		}
+		return $field_names;
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Field data
+	 *
+	 * Generates an array of objects containing field meta-data
+	 *
+	 * @access  public
+	 * @return  array
+	 */
+	function field_data()
+	{
+		$retval = array();
+		$fieldCount = $this->num_fields();
+		for ($c = 1; $c <= $fieldCount; $c++)
+		{
+			$F			  = new stdClass();
+			$F->name		= ocicolumnname($this->stmt_id, $c);
+			$F->type		= ocicolumntype($this->stmt_id, $c);
+			$F->max_length  = ocicolumnsize($this->stmt_id, $c);
+
+			$retval[] = $F;
+		}
+
+		return $retval;
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Free the result
+	 *
+	 * @return	null
+	 */		
+	function free_result()
+	{
+		if (is_resource($this->result_id))
+		{
+			ocifreestatement($this->result_id);			
+			$this->result_id = FALSE;
+		}
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Result - associative array
+	 *
+	 * Returns the result set as an array
+	 *
+	 * @access  private
+	 * @return  array
+	 */
+	function _fetch_assoc(&$row)
+	{
+		$id = ($this->curs_id) ? $this->curs_id : $this->stmt_id;
+	
+		return ocifetchinto($id, $row, OCI_ASSOC + OCI_RETURN_NULLS);	
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Result - object
+	 *
+	 * Returns the result set as an object
+	 *
+	 * @access  private
+	 * @return  object
+	 */
+	function _fetch_object()
+	{	
+		$result = array();
+
+		// If PHP 5 is being used we can fetch an result object
+		if (function_exists('oci_fetch_object'))
+		{
+			$id = ($this->curs_id) ? $this->curs_id : $this->stmt_id;
+			
+			return @oci_fetch_object($id);
+		}
+		
+		// If PHP 4 is being used we have to build our own result
+		foreach ($this->result_array() as $key => $val)
+		{
+			$obj = new stdClass();
+			if (is_array($val))
+			{
+				foreach ($val as $k => $v)
+				{
+					$obj->$k = $v;
+				}
+			}
+			else
+			{
+				$obj->$key = $val;
+			}
+			
+			$result[] = $obj;
+		}
+
+		return $result;
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Query result.  "array" version.
+	 *
+	 * @access  public
+	 * @return  array
+	 */
+	function result_array()
+	{
+		if (count($this->result_array) > 0)
+		{
+			return $this->result_array;
+		}
+
+		// oracle's fetch functions do not return arrays.
+		// The information is returned in reference parameters
+		$row = NULL;
+		while ($this->_fetch_assoc($row))
+		{
+			$this->result_array[] = $row;
+		}
+
+		return $this->result_array;
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Data Seek
+	 *
+	 * Moves the internal pointer to the desired offset.  We call
+	 * this internally before fetching results to make sure the
+	 * result set starts at zero
+	 *
+	 * @access	private
+	 * @return	array
+	 */
+	function _data_seek($n = 0)
+	{
+		return FALSE; // Not needed
+	}
+
+}
+
+
+/* End of file oci8_result.php */
 /* Location: ./system/database/drivers/oci8/oci8_result.php */
\ No newline at end of file
diff --git a/system/database/drivers/oci8/oci8_utility.php b/system/database/drivers/oci8/oci8_utility.php
index a3b6d81..cf6e9e6 100644
--- a/system/database/drivers/oci8/oci8_utility.php
+++ b/system/database/drivers/oci8/oci8_utility.php
@@ -1,122 +1,122 @@
-<?php  if ( ! defined('BASEPATH')) exit('No direct script access allowed');

-/**

- * CodeIgniter

- *

- * An open source application development framework for PHP 4.3.2 or newer

- *

- * @package		CodeIgniter

- * @author		ExpressionEngine Dev Team

- * @copyright	Copyright (c) 2008, EllisLab, Inc.

- * @license		http://codeigniter.com/user_guide/license.html

- * @link		http://codeigniter.com

- * @since		Version 1.0

- * @filesource

- */

-

-// ------------------------------------------------------------------------

-

-/**

- * Oracle Utility Class

- *

- * @category	Database

- * @author		ExpressionEngine Dev Team

- * @link		http://codeigniter.com/user_guide/database/

- */

-class CI_DB_oci8_utility extends CI_DB_utility {

-

-	/**

-	 * List databases

-	 *

-	 * @access	private

-	 * @return	bool

-	 */

-	function _list_databases()

-	{

-		return FALSE;

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Optimize table query

-	 *

-	 * Generates a platform-specific query so that a table can be optimized

-	 *

-	 * @access	private

-	 * @param	string	the table name

-	 * @return	object

-	 */

-	function _optimize_table($table)

-	{

-		return FALSE; // Is this supported in Oracle?

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Repair table query

-	 *

-	 * Generates a platform-specific query so that a table can be repaired

-	 *

-	 * @access	private

-	 * @param	string	the table name

-	 * @return	object

-	 */

-	function _repair_table($table)

-	{

-		return FALSE; // Is this supported in Oracle?

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Oracle Export

-	 *

-	 * @access	private

-	 * @param	array	Preferences

-	 * @return	mixed

-	 */

-	function _backup($params = array())

-	{

-		// Currently unsupported

-		return $this->db->display_error('db_unsuported_feature');

-	}

-

-	/**

-	 *

-	 * The functions below have been deprecated as of 1.6, and are only here for backwards

-	 * compatibility.  They now reside in dbforge().  The use of dbutils for database manipulation

-	 * is STRONGLY discouraged in favour if using dbforge.

-	 *

-	 */

-

-	/**

-	 * Create database

-	 *

-	 * @access	public

-	 * @param	string	the database name

-	 * @return	bool

-	 */

-	function _create_database($name)

-	{

-		return FALSE;

-	}

-

-	// --------------------------------------------------------------------

-

-	/**

-	 * Drop database

-	 *

-	 * @access	private

-	 * @param	string	the database name

-	 * @return	bool

-	 */

-	function _drop_database($name)

-	{

-		return FALSE;

-	}

-

-}

-

-/* End of file oci8_utility.php */

+<?php  if ( ! defined('BASEPATH')) exit('No direct script access allowed');
+/**
+ * CodeIgniter
+ *
+ * An open source application development framework for PHP 4.3.2 or newer
+ *
+ * @package		CodeIgniter
+ * @author		ExpressionEngine Dev Team
+ * @copyright	Copyright (c) 2008, EllisLab, Inc.
+ * @license		http://codeigniter.com/user_guide/license.html
+ * @link		http://codeigniter.com
+ * @since		Version 1.0
+ * @filesource
+ */
+
+// ------------------------------------------------------------------------
+
+/**
+ * Oracle Utility Class
+ *
+ * @category	Database
+ * @author		ExpressionEngine Dev Team
+ * @link		http://codeigniter.com/user_guide/database/
+ */
+class CI_DB_oci8_utility extends CI_DB_utility {
+
+	/**
+	 * List databases
+	 *
+	 * @access	private
+	 * @return	bool
+	 */
+	function _list_databases()
+	{
+		return FALSE;
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Optimize table query
+	 *
+	 * Generates a platform-specific query so that a table can be optimized
+	 *
+	 * @access	private
+	 * @param	string	the table name
+	 * @return	object
+	 */
+	function _optimize_table($table)
+	{
+		return FALSE; // Is this supported in Oracle?
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Repair table query
+	 *
+	 * Generates a platform-specific query so that a table can be repaired
+	 *
+	 * @access	private
+	 * @param	string	the table name
+	 * @return	object
+	 */
+	function _repair_table($table)
+	{
+		return FALSE; // Is this supported in Oracle?
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Oracle Export
+	 *
+	 * @access	private
+	 * @param	array	Preferences
+	 * @return	mixed
+	 */
+	function _backup($params = array())
+	{
+		// Currently unsupported
+		return $this->db->display_error('db_unsuported_feature');
+	}
+
+	/**
+	 *
+	 * The functions below have been deprecated as of 1.6, and are only here for backwards
+	 * compatibility.  They now reside in dbforge().  The use of dbutils for database manipulation
+	 * is STRONGLY discouraged in favour if using dbforge.
+	 *
+	 */
+
+	/**
+	 * Create database
+	 *
+	 * @access	public
+	 * @param	string	the database name
+	 * @return	bool
+	 */
+	function _create_database($name)
+	{
+		return FALSE;
+	}
+
+	// --------------------------------------------------------------------
+
+	/**
+	 * Drop database
+	 *
+	 * @access	private
+	 * @param	string	the database name
+	 * @return	bool
+	 */
+	function _drop_database($name)
+	{
+		return FALSE;
+	}
+
+}
+
+/* End of file oci8_utility.php */
 /* Location: ./system/database/drivers/oci8/oci8_utility.php */
\ No newline at end of file