Solved

Parse error: parse error, expecting `T_OLD_FUNCTION' or `T_FUNCTION' or `T_VAR' or `'}''

Posted on 2008-11-02
2
2,020 Views
Last Modified: 2013-12-13
What am I doing wrong?

I am making a class for connecting to a MySql database, but when testing it, it brings back a blank page. Debugging in eclipse reveals Parse error: parse error, expecting `T_OLD_FUNCTION' or `T_FUNCTION' or `T_VAR' or `'}'' in c:\program files\easyphp1-8\www\lib\framework\system.data.mysqlclient.php on line 27

/**
 * Defines a connection to the database
 *
 */
class MySqlConnection
{
	var $Connection = 0;
	var $server;
	var $username;
	var $password;
	var $database;
	/**
	 * Initializes connection to a MySQL Server
	 *
	 * @param string $Server
	 * @param string $Username
	 * @param string $Password
	 * @param string $Database
	 */
	function __construct($Server, $Username, $Password, $Database)
	{
		$res = mysql_connect($Server, $Username, $Password);
		if(!$res) throw new Exception(MySqlConnectionException);
		if(!mysql_select_db($Database, $res)) throw new Exception(MySqlDatabaseOperationException);
		$Connection = $res;
	}
	/**
	 * Returns last occured error
	 *
	 * @return string
	 */
	function GetLastError()
	{
		return mysql_error();
	}
	
	/**
	 * Closes the database connection
	 *
	 */
	function Close()
	{
		mysql_close($Connection);
	}
}

Open in new window

0
Comment
Question by:webfullcircle
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
2 Comments
 
LVL 8

Accepted Solution

by:
nahime earned 250 total points
ID: 22862077
On my test machine your code works (adding <?php at the start and ?> at the end).
I've tried to instantiate the class as in the code snippet
<?php
/**
 * Defines a connection to the database
 *
 */
class MySqlConnection
{
        var $Connection = 0;
        var $server;
        var $username;
        var $password;
        var $database;
        /**
         * Initializes connection to a MySQL Server
         *
         * @param string $Server
         * @param string $Username
         * @param string $Password
         * @param string $Database
         */
        function __construct($Server, $Username, $Password, $Database)
        {
                $res = mysql_connect($Server, $Username, $Password);
                if(!$res) throw new Exception(MySqlConnectionException);
                if(!mysql_select_db($Database, $res)) throw new Exception(MySqlDatabaseOperationException);
                $Connection = $res;
        }
        /**
         * Returns last occured error
         *
         * @return string
         */
        function GetLastError()
        {
                return mysql_error();
        }
        
        /**
         * Closes the database connection
         *
         */
        function Close()
        {
                mysql_close($Connection);
        }
}
 
$myvar = new MySqlConnection("127.0.0.1", "username", "password", "DATABASE");
?>

Open in new window

0
 
LVL 1

Author Comment

by:webfullcircle
ID: 22862106
That's odd.. I was using the require_once call and it did not work, but worked with include
0

Featured Post

SharePoint Admin?

Enable Your Employees To Focus On The Core With Intuitive Onscreen Guidance That is With You At The Moment of Need.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Author Note: Since this E-E article was originally written, years ago, formal testing has come into common use in the world of PHP.  PHPUnit (http://en.wikipedia.org/wiki/PHPUnit) and similar technologies have enjoyed wide adoption, making it possib…
This article discusses how to create an extensible mechanism for linked drop downs.
The viewer will learn how to dynamically set the form action using jQuery.
The viewer will learn how to count occurrences of each item in an array.

752 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question