home *** CD-ROM | disk | FTP | other *** search
/ InfoMagic Source Code 1993 July / THE_SOURCE_CODE_CD_ROM.iso / bsd_srcs / usr.bin / tn3270 / general / genbsubs.c next >
Encoding:
C/C++ Source or Header  |  1991-04-26  |  3.3 KB  |  126 lines

  1. /*-
  2.  * Copyright (c) 1988 The Regents of the University of California.
  3.  * All rights reserved.
  4.  *
  5.  * Redistribution and use in source and binary forms, with or without
  6.  * modification, are permitted provided that the following conditions
  7.  * are met:
  8.  * 1. Redistributions of source code must retain the above copyright
  9.  *    notice, this list of conditions and the following disclaimer.
  10.  * 2. Redistributions in binary form must reproduce the above copyright
  11.  *    notice, this list of conditions and the following disclaimer in the
  12.  *    documentation and/or other materials provided with the distribution.
  13.  * 3. All advertising materials mentioning features or use of this software
  14.  *    must display the following acknowledgement:
  15.  *    This product includes software developed by the University of
  16.  *    California, Berkeley and its contributors.
  17.  * 4. Neither the name of the University nor the names of its contributors
  18.  *    may be used to endorse or promote products derived from this software
  19.  *    without specific prior written permission.
  20.  *
  21.  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  22.  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  23.  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  24.  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  25.  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  26.  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  27.  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  28.  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  29.  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  30.  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  31.  * SUCH DAMAGE.
  32.  */
  33.  
  34. #ifndef lint
  35. static char sccsid[] = "@(#)genbsubs.c    4.2 (Berkeley) 4/26/91";
  36. #endif /* not lint */
  37.  
  38. /* The output of bunequal is the offset of the byte which didn't match;
  39.  * if all the bytes match, then we return n.
  40.  * bunequal(s1, s2, n) */
  41.  
  42. int
  43. bunequal(s1, s2, n)
  44. register char *s1, *s2;
  45. register n;
  46. {
  47.     register int i = 0;
  48.  
  49.     while (i++ < n) {
  50.     if (*s1++ != *s2++) {
  51.         break;
  52.     }
  53.     }
  54.     return(i-1);
  55. }
  56.  
  57. /* bskip(s1, n, b) : finds the first occurrence of any byte != 'b' in the 'n'
  58.  * bytes beginning at 's1'.
  59.  */
  60.  
  61. int
  62. bskip(s1, n, b)
  63. register char *s1;
  64. register int n;
  65. register int b;
  66. {
  67.     register int i = 0;
  68.  
  69.     while (i++ < n) {
  70.     if (*s1++ != b) {
  71.         break;
  72.     }
  73.     }
  74.     return(i-1);
  75. }
  76.  
  77. /*
  78.  * memNSchr(const void *s, int c, size_t n, int and)
  79.  *
  80.  * Like memchr, but the comparison is '((*s)&and) == c',
  81.  * and we increment our way through s by "stride" ('s += stride').
  82.  *
  83.  * We optimize for the most used strides of +1 and -1.
  84.  */
  85.  
  86. unsigned char *
  87. memNSchr(s, c, n, and, stride)
  88. char *s;
  89. int c;
  90. unsigned int n;
  91. int and;
  92. int stride;
  93. {
  94.     register unsigned char _c, *_s, _and;
  95.  
  96.     _and = and;
  97.     _c = (c&_and);
  98.     _s = (unsigned char *)s;
  99.     switch (stride) {
  100.     case 1:
  101.     while (n--) {
  102.         if (((*_s)&_and) == _c) {
  103.         return _s;
  104.         }
  105.         _s++;
  106.     }
  107.     break;
  108.     case -1:
  109.     while (n--) {
  110.         if (((*_s)&_and) == _c) {
  111.         return _s;
  112.         }
  113.         _s--;
  114.     }
  115.     break;
  116.     default:
  117.     while (n--) {
  118.         if (((*_s)&_and) == _c) {
  119.         return _s;
  120.         }
  121.         _s += stride;
  122.     }
  123.     }
  124.     return 0;
  125. }
  126.