download cache.h
Language: C
Copyright: Copyright 1987-96, Bit Bucket Software Co.
LOC: 85
Project Info
BinkleyTerm XE(btxe)
Server: SourceForge
Type: cvs
...e\b\btxe\btxe\btnt\sources\
   Addr.cpp
   Addr.h
   aglcrc.cpp
   aglcrc.h
   asyn_lnx.cpp
   asyn_os2.cpp
   asyn_w32.cpp
   async.h
   asyos2v1.h
   b_banner.cpp
   b_bbs.cpp
   b_faxrcv.cpp
   b_flofil.cpp
   b_frproc.cpp
   b_help.cpp
   b_initva.cpp
   b_logs.cpp
   b_passwo.cpp
   b_proto.cpp
   b_rspfil.cpp
   b_sbinit.cpp
   b_script.cpp
   b_search.cpp
   b_sessio.cpp
   b_spawn.cpp
   b_term.cpp
   b_termov.cpp
   b_today.cpp
   b_wazoo.cpp
   b_whack.cpp
   b_wzsend.cpp
   banner.cpp
   banner.h
   BasicString.h
   bbs_ctra.cpp
   bbs_data.cpp
   bbs_incl.h
   bbs_io.cpp
   bink.h
   bink_asm.cpp
   binkdlg.cpp
   binkpipe.h
   box.h
   brec.cpp
   bsend.cpp
   bt.cpp
   btconfig.cpp
   btutil.cpp
   buffer.h
   cache.cpp
   cache.h
   callback.cpp
   callerid.cpp
   callwin.cpp
   callwin.h
   capi.cpp
   cfosline.cpp
   chat.cpp
   com.h
   com_dos.h
   com_lnx.h
   com_os2.h
   com_w32.h
   common.cpp
   cpuload.cpp
   css.cpp
   css.h
   data.cpp
   debug.cpp
   debug.h
   defines.h
   dosfuncs.cpp
   emsi.cpp
   emxmxcom.cpp
   evtparse.cpp
   evtsetup.cpp
   exceptio.cpp
   exceptio.h
   Exceptions.cpp
   Exceptions.h
   externs.h
   faxproto.h
   fcfgread.cpp
   fidomail.h
   file_all.cpp
   file_dos.cpp
   file_io.h
   file_lnx.cpp
   file_os2.cpp
   file_w32.cpp
   foffsets.h
   fossil.cpp
   freepoll.cpp
   ftsc.cpp
   gethcomm.h
   heap.cpp
   history.cpp
   history.h
   hydra.cpp
   hydra.h
   includes.cpp
   includes.h
   janus.cpp
   janus.h
   keybd.h
   keyfncs.h
   keymap.cpp
   langload.cpp
   language.h
   lngmagic.h
   m7rec.cpp
   m7send.cpp
   mailer.cpp
   mailovly.cpp
   mailroot.cpp
   maxcomm.h
   maxmcp.cpp
   maxmcp.h
   maxprm.cpp
   mdm_proc.cpp
   misc.cpp
   msgs.h
   Node.cpp
   Node.h
   NodeList.cpp
   NodeList.h
   nodeproc.cpp
   os2_pm.cpp
   outbound.cpp
   pipe.cpp
   pktmsgs.cpp
   pktmsgs.h
   protcomm.cpp
   prototyp.h
   recvbark.cpp
   recvsync.cpp
   sbuf.cpp
   sbuf.h
   sched.cpp
   sched.h
   script2.cpp
   SelfTest.cpp
   SelfTest.h
   sendbark.cpp
   sendsync.cpp
   squish.cpp
   squish.h
   srif.cpp
   statetbl.cpp
   stats.cpp
   stdafx.cpp
   stdafx.h
   timer.cpp
   timer.h
   times.cpp
   types.h
   v7debug.cpp
   version.cpp
   version7.cpp
   version7.h
   vfos_dos.cpp
   vfos_lnx.cpp
   vfos_os2.cpp
   vfos_qnx.cpp
   vfos_w32.cpp
   vfossil.h
   video.h
   vt100.cpp
   vt100.h
   xfer.h
   xmrec.cpp
   xmsend.cpp
   xstring.h
   yoohoo.cpp
   zmodem.cpp
   zmodem.h

/*---------------------------------------------------------------------------*
 *
 *                               BinkleyTerm
 *
 *              (C) Copyright 1987-96, Bit Bucket Software Co.
 *     For license and contact information see /doc/orig_260/license.260.
 *
 *           This version was modified by the BinkleyTerm XE Team.
 *        For contact information see /doc/team.lst and /doc/join.us.
 *  For a complete list of changes see /doc/xe_user.doc and /doc/xe_hist.doc.
 *
 * Filename    : $Source: /cvsroot/btxe/btnt/sources/cache.h,v $
 * Revision    : $Revision: 1.1 $
 * Tagname     : $Name:  $
 * Last updated: $Date: 2005/01/01 15:18:12 $
 * State       : $State: Exp $
 *
 * Description : Cache definitions
 *
 *---------------------------------------------------------------------------*/

#ifdef CACHE

#ifndef CACHE_H
#define CACHE_H

#define BLOCKSIZE   50          /* Allocation unit size */
#define HASHSIZE    41          /* Size of hash table   */
#define KEEPORDER               /* Keep directory order */

#ifdef __BORLANDC__             /* jl 960729:  DIRECTORY is already defined in dir.h */
#  undef DIRECTORY
#endif

typedef struct FILEINFO DTA;
typedef struct _DIRECTORY DIRECTORY;
typedef struct _DIRENTRY DIRENTRY;
typedef struct _DIRBUF DIRBUF;
typedef struct _FLOWFILE FLOWFILE;
typedef struct _FLOWENT FLOWENT;

struct _DIRECTORY
{
  DIRECTORY *next;              /* -> Next in directory chain   */
  FLOWFILE *flow;               /* -> Cached flow files         */
#ifdef KEEPORDER
  DIRENTRY *list;               /* List of entries              */
#endif
  DIRENTRY *ent[HASHSIZE];      /* Hash table with entries      */
  time_t loaded;                /* If non-zero, time of loading */
  int len;                      /* Length of name               */
  char drive;                   /* Upper cased drive letter     */
  char name[1];                 /* Upper cased name, no drive   */
};

struct _DIRENTRY
{
  DIRENTRY *next;               /* -> Next in hash chain        */
#ifdef KEEPORDER
  DIRENTRY *dirnext;            /* -> Next in dir listing       */
#endif
  long time;                    /* Timestamp                    */
  long size;                    /* Size of file in bytes        */
  char attr;                    /* Attribute                    */
  char name[13];                /* Name of file                 */
};

struct _FLOWENT
{
  FLOWENT *next;                /* Next in list of files        */
  DIRECTORY *dir;               /* -> Directory                 */
  char name[13];                /* Name of file in directory    */
  int hash;                     /* Hash key of name             */
};

struct _FLOWFILE
{
  FLOWFILE *next;               /* -> Next in chain             */
  long time;                    /* Timestamp                    */
  long size;                    /* Size of file in bytes        */
  char attr;                    /* Attribute                    */
  char name[13];                /* Name of file                 */
  int hash;                     /* Hash key of name[]           */
  FLOWENT *files;               /* List of files                */
};

struct _DIRBUF
{
  int cache;                    /* Flag. Using cached method?   */
  long time;                    /* New transfer area            */
  long size;
  char attr;
  char name[13];
  union
  {
    struct
    {                           /* If not using cached method   */
      DTA dta;                  /*      Next entry to be read   */
      int more;                 /*      Flag. Is dta valid?     */
      int cleanup;              /*      Flag. Call dfind(,,2)?  */
    }
    slow;
    struct
    {                           /* Cached method                */
      DIRECTORY *dir;           /*      Directory with hash tab */
      DIRENTRY *next;           /*      Next in hash chain      */
      int hash;                 /*      Current hash key        */
      char mask[12];
    }
    fast;
  }
  u;
};

#endif /* CACHE_H */
#endif

/* $Id: cache.h,v 1.1 2005/01/01 15:18:12 vildanov Exp $ */

About Koders | Resources | Downloads | Support | Black Duck | Submit Project | Terms of Service | DMCA | Privacy Policy | Site Map| Contact Us