X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Flanguage%2Fsyntax-string-source.c;h=1d3d4d6b738c30b5c6df5c481dd0b8a912287304;hb=81579d9e9f994fb2908f50af41c3eb033d216e58;hp=c3e8d4ffd1713718ea3a0a3e7a27d9258c9a5e94;hpb=ac2f16c0421fc0d2d404f9555db5f2eb5d555a7b;p=pspp-builds.git diff --git a/src/language/syntax-string-source.c b/src/language/syntax-string-source.c index c3e8d4ff..1d3d4d6b 100644 --- a/src/language/syntax-string-source.c +++ b/src/language/syntax-string-source.c @@ -1,33 +1,32 @@ -/* - PSPPIRE --- A Graphical User Interface for PSPP - Copyright (C) 2007 Free Software Foundation +/* PSPPIRE - a graphical interface for PSPP. + Copyright (C) 2007, 2009, 2010, 2011 Free Software Foundation, Inc. - This program is free software; you can redistribute it and/or modify - it under the terms of the GNU General Public License as published by - the Free Software Foundation; either version 2 of the License, or - (at your option) any later version. + This program is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. - This program 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 General Public License for more details. + This program 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 General Public License for more details. - You should have received a copy of the GNU General Public License - along with this program; if not, write to the Free Software - Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA - 02110-1301, USA. */ + You should have received a copy of the GNU General Public License + along with this program. If not, see . */ #include -#include -#include -#include -#include +#include "language/syntax-string-source.h" #include -#include "syntax-string-source.h" +#include "libpspp/cast.h" +#include "libpspp/getl.h" +#include "libpspp/compiler.h" +#include "libpspp/str.h" + +#include "gl/xalloc.h" struct syntax_string_source { @@ -55,14 +54,15 @@ name (const struct getl_interface *i UNUSED) static int location (const struct getl_interface *i UNUSED) { - return -1; + return 0; } static void do_close (struct getl_interface *i ) { - struct syntax_string_source *sss = (struct syntax_string_source *) i; + struct syntax_string_source *sss = UP_CAST (i, struct syntax_string_source, + parent); ds_destroy (&sss->buffer); @@ -73,17 +73,17 @@ do_close (struct getl_interface *i ) static bool read_single_line (struct getl_interface *i, - struct string *line, - enum getl_syntax *syntax_rules UNUSED) + struct string *line) { - struct syntax_string_source *sss = (struct syntax_string_source *) i; + struct syntax_string_source *sss = UP_CAST (i, struct syntax_string_source, + parent); size_t next; if ( sss->posn == -1) return false; - next = ss_find_char (ds_substr (&sss->buffer, + next = ss_find_byte (ds_substr (&sss->buffer, sss->posn, -1), '\n'); ds_assign_substring (line, @@ -100,21 +100,13 @@ read_single_line (struct getl_interface *i, return true; } -struct getl_interface * -create_syntax_string_source (const char *format, ...) +static struct syntax_string_source * +create_syntax_string_source__ (void) { - va_list args; - struct syntax_string_source *sss = xzalloc (sizeof *sss); sss->posn = 0; - ds_init_empty (&sss->buffer); - - va_start (args, format); - ds_put_vformat (&sss->buffer, format, args); - va_end (args); - sss->parent.interactive = always_false; sss->parent.close = do_close; sss->parent.read = read_single_line; @@ -122,8 +114,32 @@ create_syntax_string_source (const char *format, ...) sss->parent.name = name; sss->parent.location = location; + return sss; +} + +struct getl_interface * +create_syntax_string_source (const char *s) +{ + struct syntax_string_source *sss = create_syntax_string_source__ (); + ds_init_cstr (&sss->buffer, s); + return &sss->parent; +} + +struct getl_interface * +create_syntax_format_source (const char *format, ...) +{ + struct syntax_string_source *sss; + va_list args; + + sss = create_syntax_string_source__ (); + + ds_init_empty (&sss->buffer); + + va_start (args, format); + ds_put_vformat (&sss->buffer, format, args); + va_end (args); - return (struct getl_interface *) sss; + return &sss->parent; } /* Return the syntax currently contained in S.