home *** CD-ROM | disk | FTP | other *** search
/ OS/2 Shareware BBS: 10 Tools / 10-Tools.zip / oclsrc15.zip / OCL / Source / OScan.cpp < prev    next >
C/C++ Source or Header  |  1996-08-12  |  3KB  |  121 lines

  1. // OCL - OS/2 Class Library
  2. // (c) Cubus 1995
  3. // All Rights Reserved
  4. // scanfcl.cpp
  5. // scanner classes
  6.  
  7.  
  8. /*
  9.  * Redistribution and use in source and binary forms, with or without
  10.  * modification, are permitted provided that the following conditions
  11.  * are met:
  12.  * 1. Redistributions of source code must retain the above copyright
  13.  *    notice, this list of conditions and the following disclaimer.
  14.  * 2. Neither the name Cubus nor the name Team OCL may be used to
  15.  *    endorse or promote products derived from this software
  16.  *    without specific prior written permission.
  17.  * 3. See OCL.INF for a detailed copyright notice.
  18.  *
  19.  *              THIS SOFTWARE IS PROVIDED ``AS IS'' AND
  20.  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  21.  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  22.  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  23.  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  24.  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  25.  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  26.  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  27.  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  28.  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  29.  * SUCH DAMAGE.
  30.  */
  31.  
  32. // $Header: W:/Projects/OCL/Source/rcs/OScan.cpp 1.50 1996/08/11 23:49:30 B.STEIN Release $
  33.  
  34. #define __OCL_SOURCE__
  35.  
  36. #define OINCL_OSTRING
  37. #define OINCL_BASE
  38.  
  39. #include <ocl.hpp>
  40. #include <OFcl.hpp>
  41.  
  42. // members of scan
  43.  
  44. #define Size 10*CCHMAXPATH
  45.  
  46.  
  47. OScanFcl::OScanFcl()
  48.   : Buffer(NULL), ToScan((PSZ)NULL)
  49. {
  50.  setCheck(FALSE, FALSE); 
  51. }
  52.  
  53. OScanFcl::~OScanFcl() 
  54. {
  55.  release();
  56.  good.reset(); 
  57. }
  58.  
  59.  
  60. PSZ OScanFcl::isOfType() const
  61.  return("OScanFcl"); 
  62. }
  63.  
  64.  
  65. BOOL OScanFcl::init(PCSZ FileName, PCSZ toScan)
  66. {
  67.  Buffer = new CHAR[Size];
  68.  file.open(FileName);
  69.  return(check(toScan));
  70. }
  71.  
  72.  
  73. void OScanFcl::init(PCSZ FileName)
  74. {
  75.  Buffer = new CHAR[Size];
  76.  file.open(FileName);
  77. }
  78.  
  79.  
  80. void OScanFcl::release()
  81. {
  82.  delete[] Buffer;
  83.  file.close();
  84. }
  85.  
  86. BOOL OScanFcl::check(PCSZ string)
  87. {
  88.  ToScan << string;;
  89.  
  90.  strupr(ToScan);
  91.  
  92.  while((file.getline(Buffer, Size-1)) && (!stopASAP))
  93.    {
  94.     if (strstr(strupr(Buffer), ToScan)!=NULL) {
  95.        ToScan << (PSZ) NULL; 
  96.        return(TRUE); }
  97.     memset(Buffer, 0, Size);
  98.    }
  99.  
  100.  ToScan << (PSZ) NULL; 
  101.  return(FALSE);
  102. }
  103.  
  104.  
  105. void OScanFcl::checkFiles(PCSZ text)
  106. {
  107.  pOString temp = files.getFirst();
  108.  
  109.  while((temp) && (!stopASAP))
  110.   {
  111.    init(temp->getText());
  112.    if (check(text))
  113.      good << temp->getText();
  114.    release();
  115.    temp = files.getNext(); 
  116.   }
  117. }
  118.  
  119. // end of source
  120.