⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 charc.h

📁 linux下的E_MAIL客户端源码
💻 H
📖 第 1 页 / 共 2 页
字号:
/* *  $Id: CharC.h,v 1.2 2000/06/05 17:00:41 evgeny Exp $ *   *  Copyright (c) 1994 HAL Computer Systems International, Ltd. *  *          HAL COMPUTER SYSTEMS INTERNATIONAL, LTD. *                  1315 Dell Avenue *                  Campbell, CA  95008 * * Author: Greg Hilton * Contributors: Tom Lang, Frank Bieser, and others * * This program 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 * of the License, or (at your option) any later version. * * This program 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. * * http://www.gnu.org/copyleft/gpl.html * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA. */#ifndef _CharC_h_#define _CharC_h_#include <stream.h>#include <stdio.h>#include <sys/types.h>#include <string.h>#include <X11/Intrinsic.h>class RangeC;class StringC;class SubStringC;/* * Character array class.  This class is designed to aid in the use of *    character strings that aren't guaranteed to be null-terminated.  It *    contains a character pointer and a length.  The character data cannot *    be modified. */class CharC {private:   const char	*p;   u_int	len;public://// Assignment methods//   inline void	 Set(const char *cs, u_int l) { p = cs; len = l; }   inline CharC& operator=(const CharC& c) { Set(c.p, c.len); return *this; }   inline CharC& operator=(const char *cs)				     { Set(cs, cs?strlen(cs):0); return *this; }   CharC& 	 operator=(const StringC&);   CharC& 	 operator=(const SubStringC&);   void		 CutBeg(u_int);	// Remove characters from beginning   void		 CutEnd(u_int); // Remove characters from end   inline void	 CutBoth(u_int l) { CutBeg(l); CutEnd(l); }//// Constructors//   inline CharC(const char *cs, u_int l) { Set(cs, l); }   inline CharC(const char *cs)          { *this = cs; }   inline CharC(const CharC& c)		 { *this = c; }   inline CharC(const StringC& s)	 { *this = s; }   inline CharC(const SubStringC& ss)	 { *this = ss; }   inline CharC()			 { p = NULL; len = 0; }//// Comparison methods//   int		compare(const CharC&) const;   inline int	operator<  (const CharC& s) const {return (compare(s) <  0); }   inline int	operator>  (const CharC& s) const {return (compare(s) >  0); }   inline int	operator<= (const CharC& s) const {return (compare(s) <= 0); }   inline int	operator>= (const CharC& s) const {return (compare(s) >= 0); }   inline int	operator== (const CharC& s) const {return (compare(s) == 0); }   inline int	operator!= (const CharC& s) const {return (compare(s) != 0); }   int		compare(const StringC&) const;   inline int	operator<  (const StringC& s) const {return (compare(s) <  0); }   inline int	operator>  (const StringC& s) const {return (compare(s) >  0); }   inline int	operator<= (const StringC& s) const {return (compare(s) <= 0); }   inline int	operator>= (const StringC& s) const {return (compare(s) >= 0); }   inline int	operator== (const StringC& s) const {return (compare(s) == 0); }   inline int	operator!= (const StringC& s) const {return (compare(s) != 0); }   int		compare(const char*) const;   inline int	operator<  (const char *cs) const {return (compare(cs) <  0); }   inline int	operator>  (const char *cs) const {return (compare(cs) >  0); }   inline int	operator<= (const char *cs) const {return (compare(cs) <= 0); }   inline int	operator>= (const char *cs) const {return (compare(cs) >= 0); }   inline int	operator== (const char *cs) const {return (compare(cs) == 0); }   inline int	operator!= (const char *cs) const {return (compare(cs) != 0); }   friend int	compare(const char*, const CharC&);   inline friend int	operator< (const char* cs, const CharC& c)      { return (::compare(cs, c) <  0); }   inline friend int	operator> (const char* cs, const CharC& c)      { return (::compare(cs, c) >  0); }   inline friend int	operator<=(const char* cs, const CharC& c)      { return (::compare(cs, c) <= 0); }   inline friend int	operator>=(const char* cs, const CharC& c)      { return (::compare(cs, c) >= 0); }   inline friend int	operator==(const char* cs, const CharC& c)      { return (::compare(cs, c) == 0); }   inline friend int	operator!=(const char* cs, const CharC& c)      { return (::compare(cs, c) != 0); }//// Query//   inline u_int		Len()    const { return len; }   inline u_int		Length() const { return len; }   inline u_int		Size()   const { return len; }   inline const char	*Addr()  const { return p; }   inline char	operator[](u_int i) const { return ((i >= len) ? 0 : p[i]); }   inline char	LastChar() const { return ((len > 0) ? p[len-1] : 0); }   Boolean	FollowedByNull() const;	// Is *(p+len) NULL?//// Searching at beginning//   int StartsWith(const char *cs, u_int clen, u_int offset,   		  Boolean checkCase=True) const;   int StartsWith(char, u_int offset, Boolean checkCase=True) const;   int StartsWith(char c, Boolean checkCase=True) const      { return StartsWith(c,  0, checkCase); }   int StartsWith(const char *cs, u_int offset, Boolean checkCase=True) const      { return StartsWith(cs, cs?strlen(cs):0, offset, checkCase); }   int StartsWith(const char *cs, Boolean checkCase=True) const      { return StartsWith(cs, 0, checkCase); }   int StartsWith(const CharC& c, u_int offset, Boolean checkCase=True) const      { return StartsWith(c.p, c.len, offset, checkCase); }   int StartsWith(const CharC& c, Boolean checkCase=True) const      { return StartsWith(c, 0, checkCase); }   int StartsWith(const StringC&, u_int offset, Boolean checkCase=True) const;   int StartsWith(const StringC& s, Boolean checkCase=True) const      { return StartsWith(s, 0, checkCase); }//// Searching at end//   int EndsWith(const char *cs, u_int clen, u_int offset,   		Boolean checkCase=True) const;   int EndsWith(char c, u_int offset, Boolean checkCase=True) const      { return StartsWith(c, offset, checkCase); }   int EndsWith(char c, Boolean checkCase=True) const      { return StartsWith(c, len-1, checkCase); }   int EndsWith(const char *cs, u_int offset, Boolean checkCase=True) const      { return EndsWith(cs, cs?strlen(cs):0, offset, checkCase); }   int EndsWith(const char *cs, Boolean checkCase=True) const      { return EndsWith(cs, len-1, checkCase); }   int EndsWith(const CharC& c, u_int offset, Boolean checkCase=True) const      { return EndsWith(c.p, c.len, offset, checkCase); }   int EndsWith(const CharC& c, Boolean checkCase=True) const      { return EndsWith(c, len-1, checkCase); }   int EndsWith(const StringC&, u_int offset, Boolean checkCase=True) const;   int EndsWith(const StringC& s, Boolean checkCase=True) const      { return EndsWith(s, len-1, checkCase); }//// Comparison//   int Equals(const char *cs, u_int clen, u_int offset,	      Boolean checkCase=True) const;   int Equals(char, u_int offset, Boolean checkCase=True) const;   int Equals(char c, Boolean checkCase=True) const      { return Equals(c,  0, checkCase); }   int Equals(const char *cs, u_int offset, Boolean checkCase=True) const      { return Equals(cs, cs?strlen(cs):0, offset, checkCase); }   int Equals(const char *cs, Boolean checkCase=True) const      { return Equals(cs, 0, checkCase); }   int Equals(const CharC& c, u_int offset, Boolean checkCase=True) const      { return Equals(c.p, c.len, offset, checkCase); }   int Equals(const CharC& c, Boolean checkCase=True) const      { return Equals(c, 0, checkCase); }   int Equals(const StringC&, u_int offset, Boolean checkCase=True) const;   int Equals(const StringC& s, Boolean checkCase=True) const      { return Equals(s, 0, checkCase); }//// Searching forwards//   const char *Search(const char *cs, u_int clen, u_int offset,	      Boolean checkCase=True) const;   const char *Search(char, u_int offset, Boolean checkCase=True) const;   const char *Search(char c, Boolean checkCase=True) const

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -