![]() |
Quadcap Embeddable Database |
00001 package com.quadcap.sql.types; 00002 00003 /* Copyright 1997 - 2003 Quadcap Software. All rights reserved. 00004 * 00005 * This software is distributed under the Quadcap Free Software License. 00006 * This software may be used or modified for any purpose, personal or 00007 * commercial. Open Source redistributions are permitted. Commercial 00008 * redistribution of larger works derived from, or works which bundle 00009 * this software requires a "Commercial Redistribution License"; see 00010 * http://www.quadcap.com/purchase. 00011 * 00012 * Redistributions qualify as "Open Source" under one of the following terms: 00013 * 00014 * Redistributions are made at no charge beyond the reasonable cost of 00015 * materials and delivery. 00016 * 00017 * Redistributions are accompanied by a copy of the Source Code or by an 00018 * irrevocable offer to provide a copy of the Source Code for up to three 00019 * years at the cost of materials and delivery. Such redistributions 00020 * must allow further use, modification, and redistribution of the Source 00021 * Code under substantially the same terms as this license. 00022 * 00023 * Redistributions of source code must retain the copyright notices as they 00024 * appear in each source code file, these license terms, and the 00025 * disclaimer/limitation of liability set forth as paragraph 6 below. 00026 * 00027 * Redistributions in binary form must reproduce this Copyright Notice, 00028 * these license terms, and the disclaimer/limitation of liability set 00029 * forth as paragraph 6 below, in the documentation and/or other materials 00030 * provided with the distribution. 00031 * 00032 * The Software is provided on an "AS IS" basis. No warranty is 00033 * provided that the Software is free of defects, or fit for a 00034 * particular purpose. 00035 * 00036 * Limitation of Liability. Quadcap Software shall not be liable 00037 * for any damages suffered by the Licensee or any third party resulting 00038 * from use of the Software. 00039 */ 00040 00041 import java.io.ByteArrayInputStream; 00042 import java.io.ByteArrayOutputStream; 00043 00044 import com.quadcap.sql.index.Comparator; 00045 00046 import com.quadcap.sql.io.ObjectInputStream; 00047 import com.quadcap.sql.io.ObjectOutputStream; 00048 00049 import com.quadcap.util.Debug; 00050 import com.quadcap.util.Util; 00051 00052 /** 00053 * Generic multi-field comparator implementation 00054 * 00055 * @author Stan Bailes 00056 */ 00057 public class CompareValues extends Comparator { 00058 int directions; 00059 int cnt; 00060 00061 public CompareValues() {} 00062 00063 public CompareValues(int count) { 00064 this.cnt = count; 00065 this.directions = ~((~0) << count); 00066 } 00067 00068 public void addField(boolean asc) { 00069 directions <<= 1; 00070 if (asc) directions |= 1; 00071 cnt++; 00072 } 00073 00074 //#ifdef NOTDEF 00075 //- public int compare2(byte[] a, int aoff, int alen, 00076 //- byte[] b, int boff, int blen) { 00077 //- try { 00078 //- int alim = aoff + alen; 00079 //- int blim = boff + blen; 00080 //- for (int i = 0; i < cnt; i++) { 00081 //- int as = a[aoff++] & 0xff; 00082 //- if ((as & 0x80) == 0) { 00083 //- as <<= 8; 00084 //- as |= a[aoff++] & 0xff; 00085 //- } else { 00086 //- as &= 0x7f; 00087 //- } 00088 //- int bs = b[boff++] & 0xff; 00089 //- if ((bs & 0x80) == 0) { 00090 //- bs <<= 8; 00091 //- bs |= b[boff++] & 0xff; 00092 //- } else { 00093 //- bs &= 0x7f; 00094 //- } 00095 //- for (int j = 0; j < as && j < bs; j++) { 00096 //- int av = a[aoff++] & 0xff; 00097 //- int bv = b[boff++] & 0xff; 00098 //- if (av == bv) continue; 00099 //- boolean asc = ((directions >> (cnt - i - 1)) & 1) != 0; 00100 //- return ((av < bv) ^ asc) ? -1 : 1; 00101 //- } 00102 //- } 00103 //- return 0; 00104 //- } catch (Exception e) { 00105 //- throw new RuntimeException(e.toString()); 00106 //- } 00107 //- } 00108 //#endif 00109 00110 00111 public int compare(byte[] a, int aoff, int alen, 00112 byte[] b, int boff, int blen) { 00113 try { 00114 ByteArrayInputStream ai = new ByteArrayInputStream(a, aoff, alen); 00115 ObjectInputStream aoi = new ObjectInputStream(ai); 00116 ByteArrayInputStream bi = new ByteArrayInputStream(b, boff, blen); 00117 ObjectInputStream boi = new ObjectInputStream(bi); 00118 for (int i = 0; i < cnt; i++) { 00119 Value va = (Value)aoi.readObject(); 00120 Value vb = (Value)boi.readObject(); 00121 Value cmp = Value.binop(Op.COMPARE, va, vb); 00122 //Debug.println("[" + i + "]: " + cmp + " <= (" + va + ") vs (" + vb + ")"); 00123 ValueInteger vi = (ValueInteger)cmp; 00124 int ret = vi.intValue(); 00125 if (ret != 0) { 00126 boolean asc = ((directions >> (cnt - i - 1)) & 1) != 0; 00127 ret = asc ? ret : 0 - ret; 00128 return ret; 00129 } 00130 } 00131 return 0; 00132 } catch (Exception e) { 00133 //#ifdef DEBUG 00134 Debug.print(e); 00135 Debug.println("a = " + Util.hexBytes(a, aoff, alen)); 00136 Debug.println("b = " + Util.hexBytes(b, boff, blen)); 00137 //#endif 00138 throw new RuntimeException(e.toString()); 00139 } 00140 } 00141 }