- /*--------------------------------------------------------------------- 
-    bsearch() - search a sorted array 
-   
-    Copyright (C) 2018, Philipp Klaus Krause . pkk@spth.de 
-   
-    This library is free software; you can redistribute it and/or modify it 
-    under the terms of the GNU General Public License as published by the 
-    Free Software Foundation; either version 2, or (at your option) any 
-    later version. 
-   
-    This library is distributed in the hope that it will be useful, 
-    but WITHOUT ANY WARRANTY; without even the implied warranty of 
-    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the 
-    GNU General Public License for more details. 
-   
-    You should have received a copy of the GNU General Public License  
-    along with this library; see the file COPYING. If not, write to the 
-    Free Software Foundation, 51 Franklin Street, Fifth Floor, Boston, 
-    MA 02110-1301, USA. 
-   
-    As a special exception, if you link this library with other files, 
-    some of which are compiled with SDCC, to produce an executable, 
-    this library does not by itself cause the resulting executable to 
-    be covered by the GNU General Public License. This exception does 
-    not however invalidate any other reasons why the executable file 
-    might be covered by the GNU General Public License. 
- -------------------------------------------------------------------------*/ 
-   
- #include <stdlib.h> 
-   
- void *bsearch(const void *- key , const void *- base , size_t-  nmemb , size_t-  size , int (*- compar )(const void *, const void *)-  __reentrant )
 
- { 
-         for(const char *left = base; nmemb;) 
-         { 
-                 const char *middle = left + nmemb / 2 * size; 
-                 int c = (*compar)(key, middle); 
-   
-                 if(c < 0) 
-                         nmemb = nmemb / 2;       
-                 else if(c > 0) 
-                 { 
-                         left = middle + size; 
-                         nmemb = (nmemb - 1) / 2; 
-                 } 
-                 else 
-                         return(middle); 
-         } 
-   
-         return(0); 
- } 
-   
-