which included commits to RCS files with non-trunk default branches. git-svn-id: svn://10.65.10.50/trunk@976 c028cbd2-c16b-5b4b-a496-9718f37d4682
		
			
				
	
	
		
			591 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			C++
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			591 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			C++
		
	
	
		
			Executable File
		
	
	
	
	
| /* s4str.cpp (c)Copyright Sequiter Software Inc., 1989-1993.  All rights reserved. */
 | |
| 
 | |
| #include "d4all.h"
 | |
| #ifndef S4UNIX
 | |
| #ifdef __TURBOC__
 | |
| #pragma hdrstop
 | |
| #endif  /* __TUROBC__ */
 | |
| #endif  /* S4UNIX */
 | |
| 
 | |
| #include "d4data.hpp"
 | |
| #include <ctype.h>
 | |
| #include <limits.h>
 | |
| 
 | |
| 
 | |
| #ifdef S4DLL
 | |
| char v4buffer[257] ;
 | |
| #else
 | |
| extern char v4buffer[257] ;
 | |
| #endif
 | |
| 
 | |
| #ifdef S4DEBUG
 | |
| /* Ensure the strings do not overlap */
 | |
| void s4asser_no_overlap( Str4& s1, Str4& s2 )
 | |
| {
 | |
|   if ( s1.maximum() == 0  ||  s2.maximum() == 0 )  return ;
 | |
| 
 | |
|   unsigned s1_end_pos =  s1.maximum()-1 ;
 | |
|   unsigned s2_end_pos =  s2.maximum()-1 ;
 | |
| 
 | |
|   long  s1_ptr =  long( s1.ptr() ) ;
 | |
|   long  s2_ptr =  long( s2.ptr() ) ;
 | |
| 
 | |
|   if ( s1_ptr == 0  ||  s2_ptr == 0 )
 | |
|     e4severe( e4parm, "Null String Detected" ) ;
 | |
| 
 | |
|   long  s1_end_ptr =  s1_ptr + s1_end_pos ;
 | |
|   long  s2_end_ptr =  s2_ptr + s2_end_pos ;
 | |
| 
 | |
|   if ( s1_ptr     >= s2_ptr  && s1_ptr     <= s2_end_ptr      ||
 | |
|       s1_end_ptr >= s2_ptr  && s1_end_ptr <= s2_end_ptr      ||
 | |
|       s2_ptr     >= s1_ptr  && s2_ptr     <= s1_end_ptr      ||
 | |
|       s2_end_ptr >= s1_ptr  && s2_end_ptr <= s1_end_ptr )
 | |
|     e4severe( e4parm, "Overlapping Strings Detected" ) ;
 | |
| }
 | |
| #endif
 | |
| 
 | |
| Tag4 Index4::tag( char *name )
 | |
| {
 | |
|   return Tag4( index->data, name ) ;
 | |
| }
 | |
| 
 | |
| Str4::operator char()
 | |
| {
 | |
|   if ( len() < 1 || ptr() == 0 )  return 0 ;
 | |
|   return  *ptr() ;
 | |
| }
 | |
| 
 | |
| Str4::operator double()
 | |
| {
 | |
| #ifdef S4DEBUG
 | |
|   if( ptr() == 0 ) e4severe( e4parm, "Str4::operator double() called with a null pointer" ) ;
 | |
| #endif
 | |
|   return c4atod( ptr(), len()) ;
 | |
| }
 | |
| 
 | |
| Str4::operator int()
 | |
| {
 | |
|   char *p =  ptr() ;
 | |
| #ifdef S4DEBUG
 | |
|   if( p == 0 ) e4severe( e4parm, "Str4::operator int() called with a null pointer" ) ;
 | |
| #endif
 | |
|   int i =  len() ;
 | |
|   int   r =  (int) c4atol( p,i ) ;
 | |
|   return r ;
 | |
| }
 | |
| 
 | |
| Str4::operator long()
 | |
| {
 | |
| #ifdef S4DEBUG
 | |
|   if( ptr() == 0 ) e4severe( e4parm, "Str4::operator long() called with a null pointer" ) ;
 | |
| #endif
 | |
|   return c4atol( ptr(), len()) ;
 | |
| }
 | |
| 
 | |
| int Str4::operator==( Str4& s )
 | |
| {
 | |
| #ifdef S4DEBUG
 | |
|   if( ptr() == 0 || s.ptr() == 0 ) e4severe( e4parm, "Str4::operator == called with a null pointer" ) ;
 | |
| #endif
 | |
|   unsigned l =  len() ;
 | |
|   if ( l != s.len() )  return 0 ;
 | |
| 
 | |
|   if ( memcmp( ptr(), s.ptr(), l) == 0 )
 | |
|     return 1 ;
 | |
|   else
 | |
|     return 0 ;
 | |
| }
 | |
| 
 | |
| int Str4::operator< ( Str4& s )
 | |
| {
 | |
| #ifdef S4DEBUG
 | |
|   if( ptr() == 0 || s.ptr() == 0 ) e4severe( e4parm, "Str4::operator < called with a null pointer" ) ;
 | |
| #endif
 | |
|   unsigned cmp_len ;
 | |
|   int      result ;
 | |
|   unsigned l1 =  len() ;
 | |
|   unsigned l2 =  s.len() ;
 | |
| 
 | |
|   cmp_len =  (l1<l2) ? l1 : l2 ;
 | |
|   result =  memcmp( ptr(), s.ptr(), cmp_len ) ;
 | |
|   if ( result == 0 )  return  l1 < l2 ;
 | |
|   return result < 0 ;
 | |
| }
 | |
| 
 | |
| int Str4::operator> ( Str4& s )
 | |
| {
 | |
| #ifdef S4DEBUG
 | |
|   if( ptr() == 0 || s.ptr() == 0 ) e4severe( e4parm, "Str4::operator > called with a null pointer" ) ;
 | |
| #endif
 | |
|   unsigned cmp_len ;
 | |
|   int      result ;
 | |
|   unsigned l1 =  len() ;
 | |
|   unsigned l2 =  s.len() ;
 | |
| 
 | |
|   cmp_len =  (l1<l2) ? l1 : l2 ;
 | |
|   result =  memcmp( ptr(), s.ptr(), cmp_len ) ;
 | |
|   if ( result == 0 )  return  l1 > l2 ;
 | |
|   return result > 0 ;
 | |
| }
 | |
| 
 | |
| char& Str4::operator[] ( int index )
 | |
| {
 | |
| #ifdef S4DEBUG
 | |
|   if( index > len() )
 | |
|     e4severe( e4parm, "Str4::operator[] parameter larger than size of object with S4DEBUG set" );
 | |
| #endif
 | |
|   return ptr()[index] ;
 | |
| }
 | |
| 
 | |
| int Str4::add( Str4& str_from )
 | |
| {
 | |
|   return insert( str_from, len() ) ;
 | |
| }
 | |
| 
 | |
| int Str4::add( char *ptr )
 | |
| {
 | |
|   Str4ptr p( ptr ) ;
 | |
|   return insert( p, len() ) ;
 | |
| }
 | |
| 
 | |
| int Str4::at( Str4& search_str )
 | |
| {
 | |
| #ifdef S4DEBUG
 | |
|   if( ptr() == 0 || search_str.ptr() == 0 ) e4severe( e4parm, "Str::search() called with or has a null pointer" ) ;
 | |
| #endif
 | |
|   unsigned len_search =  search_str.len() ;
 | |
|   if ( len_search == 0 )  return 0 ;
 | |
| 
 | |
|   unsigned str_len  =  len() ;
 | |
|   if ( str_len < len_search )  return -1 ;
 | |
| 
 | |
|   unsigned last_try =  str_len - len_search ;
 | |
|   char *str_ptr =  ptr() ;
 | |
|   char *search_ptr =  search_str.ptr() ;
 | |
| 
 | |
|   for ( unsigned i = 0; i <= last_try; i++ )
 | |
|     if ( str_ptr[i]  == *search_ptr )
 | |
|     {
 | |
|       for ( unsigned j = 1; j < len_search; j++ )
 | |
|         if ( str_ptr[i+j] != search_ptr[j] )  break ;
 | |
|       if ( j >= len_search )  return int(i) ;
 | |
|     }
 | |
| 
 | |
|   return -1 ;
 | |
| }
 | |
| 
 | |
| int Str4::insert( Str4& str_from, unsigned pos )
 | |
| {
 | |
| #ifdef S4DEBUG
 | |
|   s4asser_no_overlap( *this, str_from ) ;
 | |
| #endif
 | |
| 
 | |
|   changed() ;
 | |
| 
 | |
|   unsigned  start_to_len =  len() ;
 | |
| #ifdef S4DEBUG
 | |
|   if ( pos > start_to_len )  e4severe( e4info, "Str::insert()" ) ;
 | |
| #endif
 | |
|   unsigned  move_len =  start_to_len-pos ;
 | |
| 
 | |
|   unsigned  from_len =  str_from.len() ;
 | |
|   long      want_to_len =  long(start_to_len) +from_len ;
 | |
|   int rc ;
 | |
|   if ( want_to_len > UINT_MAX )
 | |
|     rc =  -1 ;
 | |
|   else
 | |
|     rc =  setLen( unsigned(want_to_len) ) ;
 | |
| 
 | |
|   unsigned to_len = len() ;
 | |
| 
 | |
|   if ( rc != 0 )
 | |
|   {
 | |
| #ifdef S4DEBUG
 | |
|     if ( to_len < start_to_len )  e4severe( e4info, "Str::insert" ) ;
 | |
| #endif
 | |
|     move_len  -=  unsigned( want_to_len - to_len ) ;
 | |
| 
 | |
|     unsigned space_avail =  to_len-pos ;
 | |
|     if ( space_avail < from_len ) from_len =  space_avail ;
 | |
|   }
 | |
| 
 | |
|   char *to_ptr =  ptr() ;
 | |
|   char *to_pos =  to_ptr+pos ;
 | |
|   memmove( to_pos+from_len, to_pos, move_len ) ;
 | |
|   memcpy( to_pos, str_from.ptr(), from_len ) ;
 | |
| 
 | |
|   if ( to_len < maximum() )
 | |
|     to_ptr[to_len] =  0 ;
 | |
|   return rc ;
 | |
| }
 | |
| 
 | |
| int Str4::assign( char *from_ptr )
 | |
| {
 | |
|   return assign( from_ptr, strlen(from_ptr) ) ;
 | |
| }
 | |
| 
 | |
| int Str4::assign( char *from_ptr, unsigned from_len )
 | |
| {
 | |
| #ifdef S4DEBUG
 | |
|   if( from_ptr == 0 ) e4severe( e4parm, "Str4::assign() called with a null pointer" ) ;
 | |
|   Str4len str(from_ptr, from_len) ;
 | |
|   s4asser_no_overlap( *this, str ) ;
 | |
| #endif
 | |
| 
 | |
|   changed() ;
 | |
| 
 | |
|   int rc = setLen( from_len ) ;
 | |
|   unsigned to_len, curLen ;
 | |
|   to_len =  curLen =  len() ;
 | |
|   if ( to_len >= from_len )
 | |
|   {
 | |
|     set( ' ' ) ;
 | |
|     to_len =  from_len ;
 | |
|     rc = 0;
 | |
|   }
 | |
| 
 | |
|   char *p = ptr() ;
 | |
|   memcpy( p, from_ptr, to_len ) ;
 | |
|   if ( curLen < maximum() )  p[curLen] =  0 ;
 | |
|   return rc ;
 | |
| }
 | |
| 
 | |
| int Str4::assign( Str4& str_from )
 | |
| {
 | |
|   return assign( str_from.ptr(), str_from.len() ) ;
 | |
| }
 | |
| 
 | |
| void Str4::assignDouble( double d, int new_len, int dec )
 | |
| {
 | |
|   changed() ;
 | |
| 
 | |
|   if ( new_len >= 0 )
 | |
|     setLen( new_len ) ;
 | |
| 
 | |
|   char *p =  ptr() ;
 | |
| 
 | |
| #ifdef S4DEBUG
 | |
|   if( p == 0 ) e4severe( e4parm, "Str4::assignDouble() called, but has a null pointer" ) ;
 | |
| #endif
 | |
| 
 | |
|   unsigned l = len() ;
 | |
| 
 | |
|   if ( dec < 0 )  dec =  decimals() ;
 | |
|   c4dtoa45( d, p, l, dec ) ;
 | |
|   if ( l < maximum() )
 | |
|     p[l] =  0 ;
 | |
| }
 | |
| 
 | |
| void Str4::assignLong( long lval, int new_len, int zeros_in_front )
 | |
| {
 | |
|   changed() ;
 | |
| 
 | |
|   if ( new_len >= 0 )
 | |
|     setLen(new_len) ;
 | |
| 
 | |
|   char *p =  ptr() ;
 | |
| 
 | |
| #ifdef S4DEBUG
 | |
|   if( p == 0 ) e4severe( e4parm, "Str4::assignLong() called, but has a null pointer" ) ;
 | |
| #endif
 | |
| 
 | |
|   int l = (int) len() ;
 | |
| 
 | |
|   if ( zeros_in_front )
 | |
|     c4ltoa45( lval, p, -l ) ;
 | |
|   else
 | |
|     c4ltoa45( lval, p, l ) ;
 | |
| 
 | |
|   if ( l < maximum() )
 | |
|     p[l] =  0 ;
 | |
| }
 | |
| 
 | |
| int Str4::encode( char *from, char *t_to, char *t_from )
 | |
| {
 | |
|   if( len() < strlen( t_to ) )
 | |
|   {
 | |
|     if( setLen( strlen( t_to)) < 0 )
 | |
|       return -1;
 | |
|   }
 | |
|   c4encode( ptr(), from, t_to, t_from ) ;
 | |
|   return 0 ;
 | |
| }
 | |
| 
 | |
| char *Str4::endPtr()
 | |
| {
 | |
| #ifdef S4DEBUG
 | |
|   if( ptr() == 0 ) e4severe( e4parm, "Str::end_ptr() called, but has a null pointer" ) ;
 | |
| #endif
 | |
|   unsigned pos =  len() ;
 | |
|   if ( pos == 0 ) return 0 ;
 | |
|   pos-- ;
 | |
|   return ptr()+pos ;
 | |
| }
 | |
| 
 | |
| char *Date4::format( char *pict )
 | |
| {
 | |
|   date4format( ptr(), v4buffer, pict ) ;
 | |
|   return v4buffer ;
 | |
| }
 | |
| 
 | |
| Str4len Str4::left( unsigned want_len )
 | |
| {
 | |
|   return substr( 0, want_len ) ;
 | |
| }
 | |
| 
 | |
| unsigned Str4::len()
 | |
| {
 | |
|   if ( ptr() == 0 ) return 0 ;
 | |
|   return strlen(ptr()) ;
 | |
| }
 | |
| 
 | |
| void Str4::lower()
 | |
| {
 | |
| #ifdef S4DEBUG
 | |
|   if( ptr() == 0 ) e4severe( e4parm, "Str::lower() called, but has a null pointer" ) ;
 | |
| #endif
 | |
|   changed() ;
 | |
|   unsigned str_len = len() ;
 | |
|   char    *str_ptr =  ptr() ;
 | |
|   for ( unsigned i = 0; i < str_len; i++ )
 | |
|     c4lower( str_ptr[i] ) ;
 | |
| }
 | |
| 
 | |
| unsigned Str4::ncpy( char *to, unsigned to_len )
 | |
| {
 | |
|   unsigned l = len() ;
 | |
| 
 | |
|   if ( to_len <= l )
 | |
|   {
 | |
|     if ( to_len-- > 0 )
 | |
|     {
 | |
|       memcpy( to, ptr(), to_len ) ;
 | |
|       to[to_len] =  0 ;
 | |
|       return to_len ;
 | |
|     }
 | |
|     return (unsigned) 0 ;
 | |
|   }
 | |
|   else
 | |
|   {
 | |
|     memcpy( to, ptr(), l ) ;
 | |
|     to[l] =  0 ;
 | |
|     return l ;
 | |
|   }
 | |
| }
 | |
| 
 | |
| int  Str4::replace( Str4& str, unsigned pos )
 | |
| {
 | |
| #ifdef S4DEBUG
 | |
|   s4asser_no_overlap( *this, str ) ;
 | |
| #endif
 | |
| 
 | |
|   changed() ;
 | |
| 
 | |
|   unsigned curLen =  len() ;
 | |
| #ifdef S4DEBUG
 | |
|   if ( pos > curLen )  e4severe( e4parm, "Str::replace()" ) ;
 | |
| #endif
 | |
|   unsigned copy_len =  str.len() ;
 | |
|   long to_final_len =  long(copy_len) + pos ;
 | |
|   int rc = 0 ;
 | |
|   if ( to_final_len > UINT_MAX )
 | |
|     rc =  -1 ;
 | |
|   else
 | |
|   {
 | |
|     if ( to_final_len > curLen )
 | |
|     {
 | |
|       rc =  setLen( unsigned(to_final_len) ) ;
 | |
|       curLen =  len() ;
 | |
|     }
 | |
|   }
 | |
|   if ( rc < 0 )
 | |
|     copy_len =  curLen - pos ;
 | |
| 
 | |
|   char *p = ptr() ;
 | |
|   memcpy( p+pos, str.ptr(), copy_len ) ;
 | |
|   if ( curLen < maximum() )  p[curLen] =  0 ;
 | |
|   return rc ;
 | |
| }
 | |
| 
 | |
| Str4len Str4::right( unsigned want_len )
 | |
| {
 | |
|   unsigned curLen =  len() ;
 | |
|   if ( want_len > curLen )  want_len =  curLen ;
 | |
|   return substr( curLen - want_len, want_len ) ;
 | |
| }
 | |
| 
 | |
| 
 | |
| void Str4::set( int chr_value )
 | |
| {
 | |
| #ifdef S4DEBUG
 | |
|   if( ptr() == 0 ) e4severe( e4parm, "Str::null_ensure() called, but has a null pointer" ) ;
 | |
| #endif
 | |
|   changed() ;
 | |
| 
 | |
|   unsigned l =  len() ;
 | |
|   char *p =  ptr() ;
 | |
|   memset( p, chr_value, l ) ;
 | |
|   if ( l < maximum() )  p[l] =  0 ;
 | |
| }
 | |
| 
 | |
| char *Str4::str()
 | |
| {
 | |
|   ncpy( v4buffer, sizeof(v4buffer) ) ;
 | |
|   return v4buffer ;
 | |
| }
 | |
| 
 | |
| void Str4::trim()
 | |
| {
 | |
| #ifdef S4DEBUG
 | |
|   if( ptr() == 0 ) e4severe( e4parm, "Str::trim() called, but has a null pointer" ) ;
 | |
| #endif
 | |
|   changed() ;
 | |
| 
 | |
|   char *p =  ptr() ;
 | |
|   for ( unsigned i = len();; )
 | |
|   {
 | |
|     if ( i == 0 )  break ;
 | |
|     i-- ;
 | |
| 
 | |
|     if ( p[i] == ' ' || p[i] == 0 )
 | |
|       p[i] =  0 ;
 | |
|     else
 | |
|     {
 | |
|       setLen(i+1) ;
 | |
|       return ;
 | |
|     }
 | |
|   }
 | |
|   setLen(0) ;
 | |
| }
 | |
| 
 | |
| int Str4::true()
 | |
| {
 | |
| #ifdef S4DEBUG
 | |
|   if( ptr() == 0 ) e4severe( e4parm, "Str4::true() called, but has a null pointer" ) ;
 | |
| #endif
 | |
|   char ch =  char(*this) ;
 | |
|   if ( ch == 'Y' || ch == 'y' || ch == 'T' || ch == 't' )
 | |
|     return 1 ;
 | |
|   else
 | |
|     return 0 ;
 | |
| }
 | |
| 
 | |
| void Str4::upper()
 | |
| {
 | |
| #ifdef S4DEBUG
 | |
|   if( ptr() == 0 ) e4severe( e4parm, "Str::upper() called, but has a null pointer" ) ;
 | |
| #endif
 | |
|   changed() ;
 | |
|   unsigned str_len = len() ;
 | |
|   char    *str_ptr =  ptr() ;
 | |
|   for ( unsigned i = 0; i < str_len; i++ )
 | |
|     c4upper( str_ptr[i] ) ;
 | |
| }
 | |
| 
 | |
| Str4len Str4::substr( unsigned pos, unsigned result_len )
 | |
| {
 | |
| #ifdef S4DEBUG
 | |
|   if( ptr() == 0 ) e4severe( e4parm, "Str::substr() called, but has a null pointer" ) ;
 | |
| #endif
 | |
|   unsigned my_len =  len() ;
 | |
| 
 | |
|   if ( long(pos) + result_len > my_len )
 | |
|   {
 | |
|     if ( pos > my_len )
 | |
|       result_len =  0 ;
 | |
|     else
 | |
|       result_len =  my_len - pos ;
 | |
|   }
 | |
| 
 | |
|   return Str4len( ptr()+pos, result_len ) ;
 | |
| }
 | |
| 
 | |
| Str4large::Str4large()
 | |
| {
 | |
|   curLen = 0;
 | |
|   buf[0] = 0;
 | |
|   buf[255] = 0;
 | |
| }
 | |
| 
 | |
| Str4large::Str4large( char *p )
 | |
| {
 | |
|   curLen = 0;
 | |
|   buf[255] = 0;
 | |
|   assign(p);
 | |
| }
 | |
| 
 | |
| Str4large::Str4large( Str4 &s )
 | |
| {
 | |
|   curLen = 0;
 | |
|   buf[255] = 0;
 | |
|   assign(s);
 | |
| }
 | |
| 
 | |
| int Str4max::setLen( unsigned new_len )
 | |
| {
 | |
|   if ( new_len <= maxLen )
 | |
|   {
 | |
|     curLen =  new_len ;
 | |
|     if ( curLen < maxLen )
 | |
|       p[curLen] =  0 ;
 | |
|     return 0 ;
 | |
|   }
 | |
|   if ( setMax( new_len )  < 0 )
 | |
|   {
 | |
|     setMax( maxLen ) ;
 | |
|     return -1 ;
 | |
|   }
 | |
|   return setLen( new_len ) ;
 | |
| }
 | |
| 
 | |
| int  Str4ten::setLen( unsigned new_len )
 | |
| {
 | |
|   if ( new_len <= 10 )
 | |
|   {
 | |
|     curLen =  new_len ;
 | |
|     buf[curLen] = 0 ;
 | |
|     return 0 ;
 | |
|   }
 | |
|   setLen( 10 ) ;
 | |
|   return -1 ;
 | |
| }
 | |
| 
 | |
| int Str4large::setLen( unsigned new_len )
 | |
| {
 | |
|   if ( new_len <= 255 )
 | |
|   {
 | |
|     curLen =  new_len ;
 | |
|     buf[curLen] = 0 ;
 | |
|     return 0 ;
 | |
|   }
 | |
|   setLen( 255 ) ;
 | |
|   return -1 ;
 | |
| }
 | |
| 
 | |
| Str4char::Str4char( char ch )
 | |
| {
 | |
|   c = ch ;
 | |
| }
 | |
| 
 | |
| Date4::Date4()
 | |
| {
 | |
|   set( ' ' ) ;
 | |
|   dt[8] = 0 ;
 | |
| }
 | |
| 
 | |
| Date4::Date4( long l )
 | |
| {
 | |
|   date4assign(dt, l) ;
 | |
|   dt[8] = 0 ;
 | |
| }
 | |
| 
 | |
| Date4::Date4( char *p )
 | |
| {
 | |
|   u4ncpy( dt, p, sizeof(dt) ) ;
 | |
| }
 | |
| 
 | |
| Date4::Date4( char *p, char *pict )
 | |
| {
 | |
|   date4init( dt, p, pict ) ;
 | |
| }
 |