test_api.php 4.3 KB
<?php
/**
* ----------------------------------------------------------------
*			XBase
*			test_api.php	
* 
*  Developer        : Erwin Kooi
*  released at      : Jan 2005
*  last modified by : Erwin Kooi
*  date modified    : Jan 2005
*                                                               
*  Info? Mail to info@cyane.nl
* 
* --------------------------------------------------------------
*
* R/W with api demonstration / compare with PHP integrated dbase functions
*
**/

	$locaplic = "c:/ms4w/apache/htdocs/i3geo";
	require_once "api_conversion.php";

	$fields = array(
		array("bool" , DBFFIELD_TYPE_LOGICAL),
		array("memo" , DBFFIELD_TYPE_MEMO),
		array("date" , DBFFIELD_TYPE_DATE),
		array("number" , DBFFIELD_TYPE_NUMERIC, 3, 0),
		array("string" , DBFFIELD_TYPE_CHAR, 50),
	);

	$di = dbase_create("test/dbase.dbf",$fields);
	$xi = xbase_create("test/xbase.dbf",$fields);
	

	dbase_add_record($di,array("T","abc","20060120",123,"string one"));
	dbase_add_record($di,array("F","def","20060121",321,"string two"));
	dbase_add_record($di,array("F","ghi","20060121",111,"string trio"));
	xbase_add_record($xi,array("T","abc","20060120",123,"string one"));
	xbase_add_record($xi,array("F","def","20060121",321,"string two"));
	xbase_add_record($xi,array("F","ghi","20060121",111,"string trio"));
	
	dbase_close($di);
	xbase_close($xi);
	$di = dbase_open("test/dbase.dbf",2);
	$xi = xbase_open("test/xbase.dbf",2);

	dbase_delete_record($di,2);
	xbase_delete_record($xi,2);
	dbase_pack($di);
	xbase_pack($xi);
	
	dbase_close($di);
	xbase_close($xi);
	$di = dbase_open("test/dbase.dbf",2);
	$xi = xbase_open("test/xbase.dbf",2);

	
	echo "dbase<br>";
	echo "index = $di <br>";
	
	echo "<br>";
	echo "xbase<br>";
	echo "index = $xi <br>";
	echo "header info: "; print_r(xbase_get_header_info($xi));
	
	dbase_close($di);
	xbase_close($xi);
	
	echo "<br><br>";
	
	$di = dbase_open("test/xbase.dbf",0);
	$xi = xbase_open("test/dbase.dbf",0);

	echo "dbase<br>";
	echo "index = $di <br>";
	echo "column count = ".dbase_numfields($di)." <br>";
	echo "record count = ".dbase_numrecords($di)." <br>";
    echo "<table>";
    for ($i=0;$i<dbase_numrecords($di);$i++) { echo "<tr>"; $r = dbase_get_record_with_names($di,$i+1); foreach ($r as $c=>$v) { echo "<td> $c=$v </td>"; } echo "</tr>"; }
	echo "</table>";

	
	echo "<br>";
	echo "xbase<br>";
	echo "index = $xi <br>";
	echo "column count = ".xbase_numfields($xi)." <br>";
	echo "record count = ".xbase_numrecords($xi)." <br>";
    echo "<table>";
    for ($i=0;$i<xbase_numrecords($xi);$i++) { echo "<tr>"; $r = xbase_get_record_with_names($xi,$i+1); foreach ($r as $c=>$v) { echo "<td> $c=$v </td>"; } echo "</tr>"; }
	echo "</table>";
	
	dbase_close($di);
	xbase_close($xi);
	
	echo "<br><br>";
	$table =& new XBaseTable("test/dbase.dbf");
	$table->open();
	echo "name: ".$table->name."<br />";
    echo "version: ".$table->version."<br />";
    echo "foxpro: ".($table->foxpro?"yes":"no")."<br />";
    echo "modifyDate: ".date("r",$table->modifyDate)."<br />";
    echo "recordCount: ".$table->recordCount."<br />";
    echo "headerLength: ".$table->headerLength."<br />";
    echo "recordByteLength: ".$table->recordByteLength."<br />";
    echo "inTransaction: ".($table->inTransaction?"yes":"no")."<br />";
    echo "encrypted: ".($table->encrypted?"yes":"no")."<br />";
    echo "mdxFlag: ".ord($table->mdxFlag)."<br />";
    echo "languageCode: ".ord($table->languageCode)."<br />";
    echo $table->toHTML();
    $table->close();
    echo "<br>";
    
	$table =& new XBaseTable("test/xbase.dbf");
	$table->open();
    echo "name: ".$table->name."<br />";
    echo "version: ".$table->version."<br />";
    echo "foxpro: ".($table->foxpro?"yes":"no")."<br />";
    echo "modifyDate: ".date("r",$table->modifyDate)."<br />";
    echo "recordCount: ".$table->recordCount."<br />";
    echo "headerLength: ".$table->headerLength."<br />";
    echo "recordByteLength: ".$table->recordByteLength."<br />";
    echo "inTransaction: ".($table->inTransaction?"yes":"no")."<br />";
    echo "encrypted: ".($table->encrypted?"yes":"no")."<br />";
    echo "mdxFlag: ".ord($table->mdxFlag)."<br />";
    echo "languageCode: ".ord($table->languageCode)."<br />";
    echo $table->toHTML();
    $table->close();
    
?>