X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Flanguage%2Fsyntax-file.c;h=9b5fd0430b56879fd92e1996c732cbe16e0c2068;hb=refs%2Ftags%2Flenny-x64-build82;hp=dde807c37c9c4409cc54b2d6049bc859679ee137;hpb=68f08c4bb53fcde16035b622bdb6e9529f9cf3ae;p=pspp-builds.git diff --git a/src/language/syntax-file.c b/src/language/syntax-file.c index dde807c3..9b5fd043 100644 --- a/src/language/syntax-file.c +++ b/src/language/syntax-file.c @@ -1,5 +1,5 @@ /* PSPP - a program for statistical analysis. - Copyright (C) 1997-9, 2000 Free Software Foundation, Inc. + Copyright (C) 1997-9, 2000, 2009 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 @@ -20,6 +20,7 @@ #include #include +#include #include #include @@ -27,8 +28,8 @@ #include #include #include -#include #include +#include #include #include #include @@ -40,6 +41,8 @@ #include "prompt.h" +#include "xalloc.h" + #include "gettext.h" #define _(msgid) gettext (msgid) @@ -60,14 +63,16 @@ struct syntax_file_source static const char * name (const struct getl_interface *s) { - const struct syntax_file_source *sfs = (const struct syntax_file_source *) s; + const struct syntax_file_source *sfs = UP_CAST (s, struct syntax_file_source, + parent); return sfs->fn; } static int line_number (const struct getl_interface *s) { - const struct syntax_file_source *sfs = (const struct syntax_file_source *) s; + const struct syntax_file_source *sfs = UP_CAST (s, struct syntax_file_source, + parent); return sfs->ln; } @@ -78,7 +83,8 @@ static bool read_syntax_file (struct getl_interface *s, struct string *line) { - struct syntax_file_source *sfs = (struct syntax_file_source *) s; + struct syntax_file_source *sfs = UP_CAST (s, struct syntax_file_source, + parent); /* Open file, if not yet opened. */ if (sfs->syntax_file == NULL) @@ -98,7 +104,8 @@ read_syntax_file (struct getl_interface *s, do { sfs->ln++; - if (!ds_read_line (line, sfs->syntax_file)) + ds_clear (line); + if (!ds_read_line (line, sfs->syntax_file, SIZE_MAX)) { if (ferror (sfs->syntax_file)) msg (ME, _("Reading `%s': %s."), sfs->fn, strerror (errno)); @@ -109,7 +116,7 @@ read_syntax_file (struct getl_interface *s, while (sfs->ln == 1 && !memcmp (ds_cstr (line), "#!", 2)); /* Echo to listing file, if configured to do so. */ - if (get_echo ()) + if (settings_get_echo ()) tab_output_text (TAB_LEFT | TAB_FIX, ds_cstr (line)); return true; @@ -118,7 +125,8 @@ read_syntax_file (struct getl_interface *s, static void syntax_close (struct getl_interface *s) { - struct syntax_file_source *sfs = (struct syntax_file_source *) s; + struct syntax_file_source *sfs = UP_CAST (s, struct syntax_file_source, + parent); if (sfs->syntax_file && EOF == fn_close (sfs->fn, sfs->syntax_file)) msg (MW, _("Closing `%s': %s."), sfs->fn, strerror (errno)); @@ -148,6 +156,6 @@ create_syntax_file_source (const char *fn) ss->parent.name = name ; ss->parent.location = line_number; - return (struct getl_interface *) ss; + return &ss->parent; }