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

📄 stream_utils.hpp

📁 ncbi源码
💻 HPP
字号:
/* * =========================================================================== * PRODUCTION $Log: stream_utils.hpp,v $ * PRODUCTION Revision 1000.1  2004/02/12 21:58:18  gouriano * PRODUCTION PRODUCTION: UPGRADED [CORE_001] Dev-tree R1.18 * PRODUCTION * =========================================================================== */#ifndef UTIL___STREAM_UTILS__HPP#define UTIL___STREAM_UTILS__HPP/*  $Id: stream_utils.hpp,v 1000.1 2004/02/12 21:58:18 gouriano Exp $ * =========================================================================== * *                            PUBLIC DOMAIN NOTICE *               National Center for Biotechnology Information * *  This software/database is a "United States Government Work" under the *  terms of the United States Copyright Act.  It was written as part of *  the author's official duties as a United States Government employee and *  thus cannot be copyrighted.  This software/database is freely available *  to the public for use. The National Library of Medicine and the U.S. *  Government have not placed any restriction on its use or reproduction. * *  Although all reasonable efforts have been taken to ensure the accuracy *  and reliability of the software and data, the NLM and the U.S. *  Government do not and cannot warrant the performance or results that *  may be obtained by using this software or data. The NLM and the U.S. *  Government disclaim all warranties, express or implied, including *  warranties of performance, merchantability or fitness for any particular *  purpose. * *  Please cite the author in any work or product based on this material. * * =========================================================================== * * Authors:  Denis Vakatov, Anton Lavrentiev * * File Description: *   Stream utilities: *   1. Push an arbitrary block of data back to C++ input stream. *   2. Non-blocking read from a stream. * */#include <corelib/ncbistre.hpp>/** @addtogroup StreamSupport * * @{ */BEGIN_NCBI_SCOPE#ifdef NCBI_COMPILER_MIPSPROclass CMIPSPRO_ReadsomeTolerantStreambuf : public CNcbiStreambuf{public:    // Do not use these two ugly, weird, ad-hoc methods, ever!!!    void MIPSPRO_ReadsomeBegin(void);    void MIPSPRO_ReadsomeEnd  (void);protected:    CMIPSPRO_ReadsomeTolerantStreambuf();    const CT_CHAR_TYPE* m_MIPSPRO_ReadsomeGptr;    unsigned int        m_MIPSPRO_ReadsomeGptrSetLevel;};inlineCMIPSPRO_ReadsomeTolerantStreambuf::CMIPSPRO_ReadsomeTolerantStreambuf() :    m_MIPSPRO_ReadsomeGptrSetLevel(0){}inlinevoid CMIPSPRO_ReadsomeTolerantStreambuf::MIPSPRO_ReadsomeBegin(void){    if (!m_MIPSPRO_ReadsomeGptrSetLevel++)        m_MIPSPRO_ReadsomeGptr = gptr();}inlinevoid CMIPSPRO_ReadsomeTolerantStreambuf::MIPSPRO_ReadsomeEnd(void){    --m_MIPSPRO_ReadsomeGptrSetLevel;}#endif // NCBI_COMPILER_MIPSPROstruct NCBI_XUTIL_EXPORT CStreamUtils {// Push the block of data [buf, buf+buf_size) back to the input stream "is".// If "del_ptr" is not NULL, then `delete[] (CT_CHAR_TYPE*) del_ptr' is called// some time between the moment you call this function and when either the// passed data is all read from the stream, or if the stream is destroyed.// Until all of the passed data is read from the stream, this block of// data may be used by the input stream.// NOTE 1:  at the function's discretion, a copy of the data can be created//          and used instead of the original [buf, buf+buf_size) area.// NOTE 2:  this data does not go to the original streambuf of "is".// NOTE 3:  it's okay if "is" is actually a duplex stream (iostream).// NOTE 4:  after a pushback "is" is not allowed to do stream positioning//          relative to current position (ios::cur); only direct-access//          (ios::beg, ios::end) seeks are okay (if permitted by "is").// NOTE 5:  stream re-positioning made after pushback clears all pushback data.    static void       Pushback(CNcbiIstream&       is,                               CT_CHAR_TYPE*       buf,                               streamsize          buf_size,                               void*               del_ptr);// Acts just like its counterpart with 4 args (above), but this variant always// copies the "pushback data" into internal buffer, so you can do whatever you// want to with the [buf, buf+buf_size) area after calling this function.    static void       Pushback(CNcbiIstream&       is,                               const CT_CHAR_TYPE* buf,                               streamsize          buf_size);// Read at most "buf_size" bytes from the stream "is" into a buffer pointed// to by "buf". This call tries its best to be non-blocking.// Return the number of bytes actually read (or 0 if nothing was read, in// case of either an error or no data currently available).    static streamsize Readsome(CNcbiIstream&       is,                               CT_CHAR_TYPE*       buf,                               streamsize          buf_size);};/* @} */END_NCBI_SCOPE/* * --------------------------------------------------------------------------- * $Log: stream_utils.hpp,v $ * Revision 1000.1  2004/02/12 21:58:18  gouriano * PRODUCTION: UPGRADED [CORE_001] Dev-tree R1.18 * * Revision 1.18  2004/01/20 20:33:52  lavr * Remove HAVE_BUGGY_IOS_CALLBACKS from this header * * Revision 1.17  2003/12/29 15:15:10  lavr * Class CShowmanycStreambuf removed * * Revision 1.16  2003/12/18 13:23:40  ucko * It seems MIPSpro also lacks showmanyc, so extend our * streambuf-with-showmanyc class to cover it as well and make it * CMIPSPRO_ReadsomeTolerantStreambuf's base class. * * Revision 1.15  2003/12/18 03:43:28  ucko * Add CGCC_ShowmanycStreambuf as a layer between streambuf and * CConn_Streambuf for the benefit of Readsome. * * Revision 1.14  2003/10/23 16:16:46  vasilche * Added Windows export modifiers. * * Revision 1.13  2003/10/22 18:14:16  lavr * Change base class of CPushback_Streambuf into CNcbiStreambuf * * Revision 1.12  2003/09/22 20:26:56  lavr * Undef HAVE_BUGGY_IOS_CALLBACKS before defining * * Revision 1.11  2003/04/17 17:50:34  siyan * Added doxygen support * * Revision 1.10  2003/04/14 21:09:07  lavr * Define HAVE_BUGGY_IOS_CALLBACKS for Sun Workshop compiler in MT mode * * Revision 1.9  2003/03/30 06:59:50  lavr * MIPS-specific workaround for lame-designed stream read ops * * Revision 1.8  2002/12/19 14:51:00  dicuccio * Added export specifier for Win32 DLL builds. * * Revision 1.7  2002/11/28 03:27:19  lavr * File description updated * * Revision 1.6  2002/11/27 21:07:19  lavr * Rename "stream_pushback" -> "stream_utils" and enclose utils in a class * * Revision 1.5  2002/11/06 03:50:39  lavr * Correct duplicated NOTE 4; move log to end; change guard macro * * Revision 1.4  2002/10/29 22:06:22  ucko * Make *buf const in the copying version of UTIL_StreamPushback. * * Revision 1.3  2002/02/05 19:37:04  lavr * List of included header files revised * * Revision 1.2  2002/02/04 20:20:28  lavr * Notes about stream repositioning added * * Revision 1.1  2001/12/09 06:28:59  vakatov * Initial revision * * =========================================================================== */#endif  /* UTIL___STREAM_UTILS__HPP */

⌨️ 快捷键说明

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