Home | Info | Community | Development | myReactOS | Contact Us
ReactOS Development > Doxygenflist.cc
Go to the documentation of this file.
00001 /* 00002 ** License Applicability. Except to the extent portions of this file are 00003 ** made subject to an alternative license as permitted in the SGI Free 00004 ** Software License B, Version 1.1 (the "License"), the contents of this 00005 ** file are subject only to the provisions of the License. You may not use 00006 ** this file except in compliance with the License. You may obtain a copy 00007 ** of the License at Silicon Graphics, Inc., attn: Legal Services, 1600 00008 ** Amphitheatre Parkway, Mountain View, CA 94043-1351, or at: 00009 ** 00010 ** http://oss.sgi.com/projects/FreeB 00011 ** 00012 ** Note that, as provided in the License, the Software is distributed on an 00013 ** "AS IS" basis, with ALL EXPRESS AND IMPLIED WARRANTIES AND CONDITIONS 00014 ** DISCLAIMED, INCLUDING, WITHOUT LIMITATION, ANY IMPLIED WARRANTIES AND 00015 ** CONDITIONS OF MERCHANTABILITY, SATISFACTORY QUALITY, FITNESS FOR A 00016 ** PARTICULAR PURPOSE, AND NON-INFRINGEMENT. 00017 ** 00018 ** Original Code. The Original Code is: OpenGL Sample Implementation, 00019 ** Version 1.2.1, released January 26, 2000, developed by Silicon Graphics, 00020 ** Inc. The Original Code is Copyright (c) 1991-2000 Silicon Graphics, Inc. 00021 ** Copyright in any portions created by third parties is as indicated 00022 ** elsewhere herein. All Rights Reserved. 00023 ** 00024 ** Additional Notice Provisions: The application programming interfaces 00025 ** established by SGI in conjunction with the Original Code are The 00026 ** OpenGL(R) Graphics System: A Specification (Version 1.2.1), released 00027 ** April 1, 1999; The OpenGL(R) Graphics System Utility Library (Version 00028 ** 1.3), released November 4, 1998; and OpenGL(R) Graphics with the X 00029 ** Window System(R) (Version 1.3), released October 19, 1998. This software 00030 ** was created using the OpenGL(R) version 1.2.1 Sample Implementation 00031 ** published by SGI, but has not been independently verified as being 00032 ** compliant with the OpenGL(R) version 1.2.1 Specification. 00033 */ 00034 00035 /* 00036 * flist.c++ 00037 * 00038 * $Date: 2006-03-12 00:07:02 +0000 (Sun, 12 Mar 2006) $ $Revision: 1.1 $ 00039 * $Header: /cygdrive/c/RCVS/CVS/ReactOS/reactos/lib/glu32/libnurbs/internals/flist.cc,v 1.1 2004/02/02 16:39:11 navaraf Exp $ 00040 */ 00041 00042 #include "glimports.h" 00043 #include "myassert.h" 00044 #include "mystdio.h" 00045 #include "flist.h" 00046 00047 /*---------------------------------------------------------------------------- 00048 * Flist::Flist - initialize a REAL number array 00049 *---------------------------------------------------------------------------- 00050 */ 00051 Flist::Flist( void ) 00052 { 00053 npts = 0; 00054 pts = 0; 00055 start = end = 0; 00056 } 00057 00058 /*---------------------------------------------------------------------------- 00059 * Flist::~Flist - free a REAL number array 00060 *---------------------------------------------------------------------------- 00061 */ 00062 Flist::~Flist( void ) 00063 { 00064 if( npts ) delete[] pts; 00065 } 00066 00067 void 00068 Flist::add( REAL x ) 00069 { 00070 pts[end++] = x; 00071 assert( end <= npts ); 00072 } 00073 00074 /*---------------------------------------------------------------------------- 00075 * Flist::filter - remove duplicate numbers from array 00076 *---------------------------------------------------------------------------- 00077 */ 00078 void Flist::filter( void ) 00079 { 00080 sorter.qsort( pts, end ); 00081 start = 0; 00082 00083 int j = 0; 00084 for( int i = 1; i < end; i++ ) { 00085 if( pts[i] == pts[i-j-1] ) 00086 j++; 00087 pts[i-j] = pts[i]; 00088 } 00089 end -= j; 00090 } 00091 00092 /*---------------------------------------------------------------------------- 00093 * Flist::grow - ensure that array is large enough 00094 *---------------------------------------------------------------------------- 00095 */ 00096 void Flist::grow( int maxpts ) 00097 { 00098 if( npts < maxpts ) { 00099 if( npts ) delete[] pts; 00100 npts = 2 * maxpts; 00101 pts = new REAL[npts]; 00102 assert( pts != 0 ); 00103 } 00104 start = end = 0; 00105 } 00106 00107 /*---------------------------------------------------------------------------- 00108 * Flist::taper - ignore head and tail of array 00109 *---------------------------------------------------------------------------- 00110 */ 00111 void Flist::taper( REAL from, REAL to ) 00112 { 00113 while( pts[start] != from ) 00114 start++; 00115 00116 while( pts[end-1] != to ) 00117 end--; 00118 } 00119 00120 Generated on Sat May 26 2012 04:22:16 for ReactOS by
1.7.6.1
|