Subversion Repositories Kolibri OS

Rev

Blame | Last modification | View Log | Download | RSS feed

  1. /****************************************************************************
  2. *
  3. *                            Open Watcom Project
  4. *
  5. *    Portions Copyright (c) 1983-2002 Sybase, Inc. All Rights Reserved.
  6. *
  7. *  ========================================================================
  8. *
  9. *    This file contains Original Code and/or Modifications of Original
  10. *    Code as defined in and that are subject to the Sybase Open Watcom
  11. *    Public License version 1.0 (the 'License'). You may not use this file
  12. *    except in compliance with the License. BY USING THIS FILE YOU AGREE TO
  13. *    ALL TERMS AND CONDITIONS OF THE LICENSE. A copy of the License is
  14. *    provided with the Original Code and Modifications, and is also
  15. *    available at www.sybase.com/developer/opensource.
  16. *
  17. *    The Original Code and all software distributed under the License are
  18. *    distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
  19. *    EXPRESS OR IMPLIED, AND SYBASE AND ALL CONTRIBUTORS HEREBY DISCLAIM
  20. *    ALL SUCH WARRANTIES, INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF
  21. *    MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR
  22. *    NON-INFRINGEMENT. Please see the License for the specific language
  23. *    governing rights and limitations under the License.
  24. *
  25. *  ========================================================================
  26. *
  27. * Description:  Implementation of BSD style strlcat() and wcslcat().
  28. *
  29. ****************************************************************************/
  30.  
  31.  
  32. #include "variety.h"
  33. #include "widechar.h"
  34. #include <string.h>
  35.  
  36.  
  37. _WCRTLINK size_t __F_NAME(strlcat,wcslcat)( CHAR_TYPE *dst, const CHAR_TYPE *t, size_t n )
  38. {
  39.     CHAR_TYPE   *s;
  40.     size_t      len;
  41.  
  42.     s = dst;
  43.     // Find end of string in destination buffer but don't overrun
  44.     for( len = n; len; --len ) {
  45.         if( *s == NULLCHAR ) break;
  46.         ++s;
  47.     }
  48.     // If no null char was found in dst, the buffer is messed up; don't
  49.     // touch it
  50.     if( *s == NULLCHAR ) {
  51.         --len;      // Decrement len to leave space for terminating null
  52.         while( len != 0 ) {
  53.             *s = *t;
  54.             if( *s == NULLCHAR ) {
  55.                 return( n - len - 1 );
  56.             }
  57.             ++s;
  58.             ++t;
  59.             --len;
  60.         }
  61.         // Buffer not large enough. Terminate and figure out desired length
  62.         *s = NULLCHAR;
  63.         while( *t++ != NULLCHAR )
  64.             ++n;
  65.         --n;
  66.     }
  67.     return( n );
  68. }
  69.