Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: orxonox.OLD/trunk/src/lib/shell/shell_buffer.h @ 5175

Last change on this file since 5175 was 5175, checked in by bensch, 19 years ago

orxonox/trunk: cleaner outtakes of the ShellBuffer

File size: 2.3 KB
Line 
1/*!
2 * @file shell_buffer.h
3 * @brief The Shell buffer Tasks
4*/
5
6#ifndef _SHELL_BUFFER_H
7#define _SHELL_BUFFER_H
8
9#include <stdarg.h>
10
11#define      SHELL_BUFFER_SIZE       16384         //!< The Size of the input-buffers (should be large enough to carry any kind of input)
12
13// FORWARD DECLARATION
14template<class T> class tList;
15template<class T> class tIterator;
16#ifndef NULL
17#define NULL 0            //!< a pointer to NULL
18#endif
19
20//! A class for ...
21class ShellBuffer {
22
23 public:
24  virtual ~ShellBuffer();
25  /** @returns a Pointer to the only object of this Class */
26  inline static ShellBuffer* getInstance() { if (!ShellBuffer::singletonRef) ShellBuffer::singletonRef = new ShellBuffer();  return ShellBuffer::singletonRef; };
27  /** @returns true if this class is instanciated, false otherwise */
28  inline static bool isInstanciated() { return (ShellBuffer::singletonRef == NULL)?true:false; };
29
30  // BUFFER //
31  /** @param bufferSize the new Buffer-Size */
32  void setBufferSize(unsigned int bufferSize) { this->bufferSize = bufferSize; };
33  void flushBuffers();
34  static bool addBufferLineStatic(const char* line, ...);
35  void addBufferLine(const char* line, va_list arg);
36  void moveBuffer(unsigned int lineCount);
37// void moveBufferTo(unsigned int lineNumber);
38  const char* getBufferLine(unsigned int lineNumber);
39  inline tIterator<char>*  getBufferIterator() const { return bufferIterator; };
40
41  private:
42    ShellBuffer();
43
44
45  private:
46   static ShellBuffer*      singletonRef;                       //!< The singleton-reference to the only memeber of this class.
47   unsigned int             bufferSize;                         //!< The Size of the buffer
48   tList<char>*             buffer;                             //!< A list of stored char-arrays(strings) to store the history
49   tIterator<char>*         bufferIterator;                     //!< An iterator for the Shells main buffer.
50
51   char                     bufferArray[SHELL_BUFFER_SIZE];     //!< a BUFFER for fast writing
52   char                     keepBufferArray[SHELL_BUFFER_SIZE]; //!< a BUFFER to have multi-non-newLine commands be copied into the shell.
53   bool                     keepBuffer;                         //!< if the keepbuffer contains unfinished lines.
54
55   unsigned long            lineCount;                          //!< how many Lines have been written out so far.
56};
57
58#endif /* _SHELL_BUFFER_H */
Note: See TracBrowser for help on using the repository browser.