From 62f06e6c77e82b8be16d069c6b7a19add1aa9e13 Mon Sep 17 00:00:00 2001 From: alexpeshkoff Date: Fri, 1 Mar 2013 13:50:37 +0000 Subject: [PATCH] Postfix for CORE-3990 --- src/isql/InputDevices.cpp | 41 ++++++++++++++++++++++++++++++++++----- src/isql/InputDevices.h | 20 ++++++++++++++++--- src/isql/isql.epp | 3 +++ 3 files changed, 56 insertions(+), 8 deletions(-) diff --git a/src/isql/InputDevices.cpp b/src/isql/InputDevices.cpp index c630a3998b..ed66b364f6 100644 --- a/src/isql/InputDevices.cpp +++ b/src/isql/InputDevices.cpp @@ -247,11 +247,18 @@ void InputDevices::saveCommand(const char* statement, const char* term) if (m_ifp.indev_fpointer == stdin) { FILE* f = m_ofp.indev_fpointer; - fb_assert(f); - fputs(statement, f); - fputs(term, f); - // Add newline to make the file more readable. - fputc('\n', f); + if (f) + { + fputs(statement, f); + fputs(term, f); + // Add newline to make the file more readable. + fputc('\n', f); + } + else + { + Command* command = new Command(statement, term); + commands.add(command); + } } } @@ -270,3 +277,27 @@ void InputDevices::gotoEof() fseek(m_ifp.indev_fpointer, 0, SEEK_END); } +InputDevices::Command::Command(const char* statement, const char* term) + : m_statement(getPool()) +{ + m_statement = statement; + m_statement += term; +} + +void InputDevices::Command::toFile(FILE* f) +{ + fputs(m_statement.c_str(), f); + // Add newline to make the file more readable. + fputc('\n', f); +} + +void InputDevices::commandsToFile(FILE* f) +{ + for (unsigned n = 0; n < commands.getCount(); ++n) + { + commands[n]->toFile(f); + delete commands[n]; + } + + commands.clear(); +} diff --git a/src/isql/InputDevices.h b/src/isql/InputDevices.h index 90b3714781..1b4566a849 100644 --- a/src/isql/InputDevices.h +++ b/src/isql/InputDevices.h @@ -27,6 +27,8 @@ #include "../common/classes/fb_string.h" #include "../common/os/path_utils.h" +#include "../common/classes/array.h" + #include // This is basically a stack of input files caused by the INPUT command, @@ -83,12 +85,24 @@ public: void saveCommand(const char* statement, const char* term); bool readingStdin() const; void gotoEof(); + void commandsToFile(FILE* fpointer); private: size_t m_count; indev* m_head; indev m_ifp; indev m_ofp; + + class Command : public Firebird::GlobalStorage + { + public: + Command(const char* statement, const char* term); + void toFile(FILE* fpointer); + private: + Firebird::string m_statement; + }; + + Firebird::HalfStaticArray commands; }; @@ -105,12 +119,12 @@ inline void InputDevices::indev::close() inline InputDevices::InputDevices() - : m_count(0), m_head(0), m_ifp(0, "", ""), m_ofp(0, "", "") + : m_count(0), m_head(0), m_ifp(0, "", ""), m_ofp(0, "", ""), commands(*getDefaultMemoryPool()) { } -inline InputDevices::InputDevices(Firebird::MemoryPool&) - : m_count(0), m_head(0), m_ifp(0, "", ""), m_ofp(0, "", "") +inline InputDevices::InputDevices(Firebird::MemoryPool& p) + : m_count(0), m_head(0), m_ifp(0, "", ""), m_ofp(0, "", ""), commands(p) { } diff --git a/src/isql/isql.epp b/src/isql/isql.epp index dfe6ee0c50..2a0aa5918d 100644 --- a/src/isql/isql.epp +++ b/src/isql/isql.epp @@ -4465,7 +4465,10 @@ static processing_state edit(const TEXT* const* cmd) const char* Tmpfile = filename.c_str(); FILE* f = fopen(Tmpfile, "w+"); // It was w+b if (f) + { Ofp.init(f, Tmpfile, Tmpfile); + Filelist->commandsToFile(f); + } else { // If we can't open a temp file then bail