16
16
/* readline for batch mode */
19
#include "drizzled/internal/my_sys.h"
20
#include "client/linebuffer.h"
18
#include <drizzled/global.h>
19
#include <mysys/my_sys.h>
20
#include <mystrings/m_string.h>
21
#include "my_readline.h"
24
23
using namespace std;
25
using namespace drizzled;
27
LineBuffer::LineBuffer(uint32_t my_max_size,FILE *my_file)
31
max_size(my_max_size),
34
line.reserve(max_size);
37
void LineBuffer::addString(const string &str)
39
buffer << str << endl;
42
char *LineBuffer::readline()
48
if ((read_count= read(fileno(file), (&line[0]), max_size-1)))
25
static bool init_line_buffer(LINE_BUFFER *buffer,File file,uint32_t size,
27
static bool init_line_buffer_from_string(LINE_BUFFER *buffer,char * str);
28
static size_t fill_buffer(LINE_BUFFER *buffer);
29
static char *intern_read_line(LINE_BUFFER *buffer,uint32_t *out_length);
32
LINE_BUFFER *batch_readline_init(uint32_t max_size,FILE *file)
34
LINE_BUFFER *line_buff;
35
if (!(line_buff=(LINE_BUFFER*)
36
my_malloc(sizeof(*line_buff),MYF(MY_WME | MY_ZEROFILL))))
38
if (init_line_buffer(line_buff,fileno(file),IO_SIZE,max_size))
47
char *batch_readline(LINE_BUFFER *line_buff)
52
if (!(pos=intern_read_line(line_buff,&out_length)))
54
if (out_length && pos[out_length-1] == '\n')
55
if (--out_length && pos[out_length-1] == '\r') /* Remove '\n' */
56
out_length--; /* Remove '\r' */
57
line_buff->read_length=out_length;
63
void batch_readline_end(LINE_BUFFER *line_buff)
67
free(line_buff->buffer);
73
LINE_BUFFER *batch_readline_command(LINE_BUFFER *line_buff, char * str)
76
if (!(line_buff=(LINE_BUFFER*)
77
my_malloc(sizeof(*line_buff),MYF(MY_WME | MY_ZEROFILL))))
79
if (init_line_buffer_from_string(line_buff,str))
88
/*****************************************************************************
89
Functions to handle buffered readings of lines from a stream
90
******************************************************************************/
93
init_line_buffer(LINE_BUFFER *buffer,File file,uint32_t size,uint32_t max_buffer)
97
buffer->max_size=max_buffer;
98
if (!(buffer->buffer = (char*) my_malloc(buffer->bufread+1,
99
MYF(MY_WME | MY_FAE))))
101
buffer->end_of_line=buffer->end=buffer->buffer;
102
buffer->buffer[0]=0; /* For easy start test */
107
init_line_buffer_from_string can be called on the same buffer
108
several times. the resulting buffer will contain a
109
concatenation of all strings separated by spaces
111
static bool init_line_buffer_from_string(LINE_BUFFER *buffer,char * str)
113
uint old_length=(uint)(buffer->end - buffer->buffer);
114
uint length= (uint) strlen(str);
115
if (!(buffer->buffer= buffer->start_of_line= buffer->end_of_line=
116
(char*) my_realloc((unsigned char*) buffer->buffer, old_length+length+2,
117
MYF(MY_FAE|MY_ALLOW_ZERO_PTR))))
119
buffer->end= buffer->buffer + old_length;
122
memcpy(buffer->end, str, length);
123
buffer->end[length]= '\n';
124
buffer->end[length+1]= 0;
125
buffer->end+= length+1;
133
Fill the buffer retaining the last n bytes at the beginning of the
134
newly filled buffer (for backward context). Returns the number of new
135
bytes read from disk.
138
static size_t fill_buffer(LINE_BUFFER *buffer)
141
uint bufbytes= (uint) (buffer->end - buffer->start_of_line);
144
return 0; /* Everything read */
146
/* See if we need to grow the buffer. */
150
uint start_offset=(uint) (buffer->start_of_line - buffer->buffer);
151
read_count=(buffer->bufread - bufbytes)/IO_SIZE;
152
if ((read_count*=IO_SIZE))
154
buffer->bufread *= 2;
155
if (!(buffer->buffer = (char*) my_realloc(buffer->buffer,
157
MYF(MY_WME | MY_FAE))))
159
buffer->start_of_line=buffer->buffer+start_offset;
160
buffer->end=buffer->buffer+bufbytes;
163
/* Shift stuff down. */
164
if (buffer->start_of_line != buffer->buffer)
166
memcpy(buffer->buffer, buffer->start_of_line, (uint) bufbytes);
167
buffer->end=buffer->buffer+bufbytes;
170
/* Read in new stuff. */
171
if ((read_count= my_read(buffer->file, (unsigned char*) buffer->end, read_count,
172
MYF(MY_WME))) == MY_FILE_ERROR)
175
/* Kludge to pretend every nonempty file ends with a newline. */
176
if (!read_count && bufbytes && buffer->end[-1] != '\n')
178
buffer->eof = read_count = 1;
181
buffer->end_of_line=(buffer->start_of_line=buffer->buffer)+bufbytes;
182
buffer->end+=read_count;
183
*buffer->end=0; /* Sentinel */
189
char *intern_read_line(LINE_BUFFER *buffer,uint32_t *out_length)
195
buffer->start_of_line=buffer->end_of_line;
198
pos=buffer->end_of_line;
199
while (*pos != '\n' && *pos)
201
if (pos == buffer->end)
50
line[read_count+1]= '\0';
203
if ((uint) (pos - buffer->start_of_line) < buffer->max_size)
205
if (!(length=fill_buffer(buffer)) || length == (size_t) -1)
209
pos--; /* break line here */
211
buffer->end_of_line=pos+1;
212
*out_length=(uint32_t) (pos + 1 - buffer->eof - buffer->start_of_line);
213
return(buffer->start_of_line);
57
buffer.getline(&line[0],max_size);