Category : OS/2 Files
Archive   : GPPDEV8F.ZIP
Filename : FPLEX.HP
/*
Copyright (C) 1988 Free Software Foundation
written by Doug Lea ([email protected])
based on code by Marc Shapiro ([email protected])
This file is part of the GNU C++ Library. This library is free
software; you can redistribute it and/or modify it under the terms of
the GNU Library General Public License as published by the Free
Software Foundation; either version 2 of the License, 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 Library General Public License for more details.
You should have received a copy of the GNU Library General Public
License along with this library; if not, write to the Free Software
Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
*/
#ifndef _
#ifdef __GNUG__
#pragma interface
#endif
#define _
#include "
class
{
public:
// fence = 0;
// csize = default
// fence = 0;
// csize = maxsize
int maxsize); // fence=lo
// csize = maxsize
int hi, // fence = hi+1
const
int maxsize = 0); // csize = maxsize
// or fence - lo if 0
~
void operator= (const
// virtuals
const
const
Pix first() const;
Pix last() const;
void prev(Pix& ptr) const;
void next(Pix& ptr) const;
int owns(Pix p) const;
const
int low() const;
int high() const;
int valid(int idx) const;
void prev(int& idx) const;
void next(int& x) const;
const
int Pix_to_index(Pix p) const;
Pix index_to_Pix(int idx) const;
int can_add_high() const;
int can_add_low() const;
int full() const;
int add_high(const
int del_high ();
int add_low (const
int del_low ();
void fill(const
void fill(const
void clear();
void reverse();
int OK () const;
};
inline int
{
return idx >= lo && idx < fnc;
}
inline int
{
return lo;
}
inline int
{
return fnc - 1;
}
inline Pix
{
return (Pix)(hd->
}
inline void
{
p = Pix(hd->
}
inline void
{
p = Pix(hd->
}
inline Pix
{
return Pix(hd->
}
inline int
{
return fnc - lo == csize;
}
inline void
{
--idx;
}
inline void
{
++idx;
}
inline
{
if (idx < lo || idx >= fnc) index_error();
return *(hd->pointer_to(idx));
}
inline
{
return *((
}
inline
{
if (empty()) index_error();
return *(hd->pointer_to(lo));
}
inline
{
if (empty()) index_error();
return *(hd->pointer_to(fnc - 1));
}
inline const
{
if (idx < lo || idx >= fnc) index_error();
return *(hd->pointer_to(idx));
}
inline const
{
return *((const
}
inline const
{
if (empty()) index_error();
return *(hd->pointer_to(lo));
}
inline const
{
if (empty()) index_error();
return *(hd->pointer_to(fnc - 1));
}
inline int
{
return hd->can_grow_high();
}
inline int
{
return hd->can_grow_low();
}
inline int
{
if (!can_add_high()) full_error();
*((hd->
return fnc++;
}
inline int
{
if (empty()) empty_error();
hd->
return --fnc - 1;
}
inline int
{
if (!can_add_low()) full_error();
*((hd->
return --lo;
}
inline int
{
if (empty()) empty_error();
hd->
return ++lo;
}
inline int
{
return hd->actual_pointer((
}
inline int
{
if (!hd->actual_pointer((const
return hd->index_of((const
}
inline Pix
{
if (idx < lo || idx >= fnc) index_error();
return Pix(hd->pointer_to(idx));
}
inline
#endif
Very nice! Thank you for this wonderful archive. I wonder why I found it only now. Long live the BBS file archives!
This is so awesome! 😀 I’d be cool if you could download an entire archive of this at once, though.
But one thing that puzzles me is the “mtswslnkmcjklsdlsbdmMICROSOFT” string. There is an article about it here. It is definitely worth a read: http://www.os2museum.com/wp/mtswslnk/