paul | 718e374 | 2002-12-13 20:15:29 +0000 | [diff] [blame] | 1 | /* |
| 2 | * Buffering to output and input. |
| 3 | * Copyright (C) 1998 Kunihiro Ishiguro |
| 4 | * |
| 5 | * This file is part of GNU Zebra. |
| 6 | * |
| 7 | * GNU Zebra is free software; you can redistribute it and/or modify |
| 8 | * it under the terms of the GNU General Public License as published |
| 9 | * by the Free Software Foundation; either version 2, or (at your |
| 10 | * option) any later version. |
| 11 | * |
| 12 | * GNU Zebra is distributed in the hope that it will be useful, but |
| 13 | * WITHOUT ANY WARRANTY; without even the implied warranty of |
| 14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
| 15 | * General Public License for more details. |
| 16 | * |
| 17 | * You should have received a copy of the GNU General Public License |
| 18 | * along with GNU Zebra; see the file COPYING. If not, write to the |
| 19 | * Free Software Foundation, Inc., 59 Temple Place - Suite 330, |
| 20 | * Boston, MA 02111-1307, USA. |
| 21 | */ |
| 22 | |
| 23 | #ifndef _ZEBRA_BUFFER_H |
| 24 | #define _ZEBRA_BUFFER_H |
| 25 | |
| 26 | /* Buffer master. */ |
| 27 | struct buffer |
| 28 | { |
| 29 | /* Data list. */ |
| 30 | struct buffer_data *head; |
| 31 | struct buffer_data *tail; |
| 32 | |
| 33 | /* Current allocated data. */ |
| 34 | unsigned long alloc; |
| 35 | |
ajs | 49ff6d9 | 2004-11-04 19:26:16 +0000 | [diff] [blame] | 36 | /* Size of each buffer_data chunk. */ |
paul | 718e374 | 2002-12-13 20:15:29 +0000 | [diff] [blame] | 37 | unsigned long size; |
| 38 | |
| 39 | /* For allocation. */ |
| 40 | struct buffer_data *unused_head; |
| 41 | struct buffer_data *unused_tail; |
| 42 | |
| 43 | /* Current total length of this buffer. */ |
| 44 | unsigned long length; |
| 45 | }; |
| 46 | |
| 47 | /* Data container. */ |
| 48 | struct buffer_data |
| 49 | { |
paul | 718e374 | 2002-12-13 20:15:29 +0000 | [diff] [blame] | 50 | struct buffer_data *next; |
| 51 | struct buffer_data *prev; |
| 52 | |
paul | 718e374 | 2002-12-13 20:15:29 +0000 | [diff] [blame] | 53 | /* Current pointer. */ |
| 54 | unsigned long cp; |
| 55 | |
| 56 | /* Start pointer. */ |
| 57 | unsigned long sp; |
ajs | 49ff6d9 | 2004-11-04 19:26:16 +0000 | [diff] [blame] | 58 | |
| 59 | /* Actual data stream (variable length). */ |
| 60 | unsigned char data[0]; /* real dimension is buffer->size */ |
paul | 718e374 | 2002-12-13 20:15:29 +0000 | [diff] [blame] | 61 | }; |
| 62 | |
| 63 | /* Buffer prototypes. */ |
| 64 | struct buffer *buffer_new (size_t); |
paul | 9035efa | 2004-10-10 11:56:56 +0000 | [diff] [blame] | 65 | int buffer_write (struct buffer *, const void *, size_t); |
paul | 718e374 | 2002-12-13 20:15:29 +0000 | [diff] [blame] | 66 | void buffer_free (struct buffer *); |
| 67 | char *buffer_getstr (struct buffer *); |
| 68 | int buffer_putc (struct buffer *, u_char); |
paul | 9035efa | 2004-10-10 11:56:56 +0000 | [diff] [blame] | 69 | int buffer_putstr (struct buffer *, const char *); |
paul | 718e374 | 2002-12-13 20:15:29 +0000 | [diff] [blame] | 70 | void buffer_reset (struct buffer *); |
| 71 | int buffer_flush_all (struct buffer *, int); |
| 72 | int buffer_flush_vty_all (struct buffer *, int, int, int); |
| 73 | int buffer_flush_window (struct buffer *, int, int, int, int, int); |
| 74 | int buffer_empty (struct buffer *); |
| 75 | |
ajs | 49ff6d9 | 2004-11-04 19:26:16 +0000 | [diff] [blame] | 76 | /* buffer_flush_available attempts to flush the queued data to the given |
| 77 | file descriptor. It returns 0 if the buffers are now empty (after |
| 78 | flushing), or 1 if more data remains on the buffer queue (must be flushed |
| 79 | later). This function (unlike the other buffer_flush* functions) is |
| 80 | designed to work with non-blocking file descriptors. */ |
| 81 | int buffer_flush_available(struct buffer *, int fd); |
| 82 | |
paul | 718e374 | 2002-12-13 20:15:29 +0000 | [diff] [blame] | 83 | #endif /* _ZEBRA_BUFFER_H */ |