summaryrefslogtreecommitdiff
path: root/src/smt/managed_ostreams.h
diff options
context:
space:
mode:
authorTim King <taking@google.com>2016-01-28 12:35:45 -0800
committerTim King <taking@google.com>2016-01-28 12:35:45 -0800
commit2ba8bb701ce289ba60afec01b653b0930cc59298 (patch)
tree46df365b7b41ce662a0f94de5b11c3ed20829851 /src/smt/managed_ostreams.h
parent42b665f2a00643c81b42932fab1441987628c5a5 (diff)
Adding listeners to Options.
- Options -- Added the new option attribute :notify. One can get a notify() call on the Listener after a the option's value is updated. This is the new preferred way to achieve dynamic dispatch for options. -- Removed SmtOptionsHandler and pushed its functionality into OptionsHandler and Listeners. -- Added functions to Options for registering listeners of the notify calls. -- Changed a number of options to use the new listener infrastructure. -- Fixed a number of warnings in options. -- Added the ArgumentExtender class to better capture how arguments are inserted while parsing options and ease memory management. Previously this was the "preemptGetopt" procedure. -- Moved options/options_handler_interface.{cpp,h} to options/options_handler.{cpp,h}. - Theories -- Reimplemented alternative theories to use a datastructure stored on TheoryEngine instead of on Options. - Ostream Handling: -- Added new functionality that generalized how ostreams are opened, options/open_stream.h. -- Simplified the memory management for different ostreams, smt/managed_ostreams.h. -- Had the SmtEnginePrivate manage the memory for the ostreams set by options. -- Simplified how the setting of ostreams are updated, smt/update_ostream.h. - Configuration and Tags: -- Configuration can now be used during predicates and handlers for options. -- Moved configuration.{cpp,h,i} and configuration_private.h from util/ into base/. -- Moved {Debug,Trace}_tags.* from being generated in options/ into base/. - cvc4_private.h -- Upgraded #warning's in cvc4_private.h and cvc4_private_library.h to #error's. -- Added public first-order (non-templatized) member functions for options get and set the value of options outside of libcvc4. Fixed all of the use locations. -- Made lib/lib/clock_gettime.h a cvc4_private_library.h header. - Antlr -- Fixed antlr and cvc4 macro definition conflicts that caused warnings. - SmtGlobals -- Refactored replayStream and replayLog out of SmtGlobals. -- Renamed SmtGlobals to LemmaChannels and moved the implementation into smt_util/lemma_channels.{h,cpp}.
Diffstat (limited to 'src/smt/managed_ostreams.h')
-rw-r--r--src/smt/managed_ostreams.h181
1 files changed, 181 insertions, 0 deletions
diff --git a/src/smt/managed_ostreams.h b/src/smt/managed_ostreams.h
new file mode 100644
index 000000000..05d026b24
--- /dev/null
+++ b/src/smt/managed_ostreams.h
@@ -0,0 +1,181 @@
+/********************* */
+/*! \file managed_ostreams.h
+ ** \verbatim
+ ** Original author: Tim King
+ ** Major contributors: none
+ ** Minor contributors (to current version): none
+ ** This file is part of the CVC4 project.
+ ** Copyright (c) 2009-2016 New York University and The University of Iowa
+ ** See the file COPYING in the top-level source directory for licensing
+ ** information.\endverbatim
+ **
+ ** \brief Wrappers to handle memory management of ostreams.
+ **
+ ** This file contains wrappers to handle special cases of managing memory
+ ** related to ostreams.
+ **/
+
+#include "cvc4_private.h"
+
+#ifndef __CVC4__MANAGED_OSTREAMS_H
+#define __CVC4__MANAGED_OSTREAMS_H
+
+#include <ostream>
+
+#include "options/open_ostream.h"
+#include "smt/update_ostream.h"
+
+namespace CVC4 {
+
+/** This abstracts the management of ostream memory and initialization. */
+class ManagedOstream {
+ public:
+ /** Initially getManagedOstream() == NULL. */
+ ManagedOstream();
+ virtual ~ManagedOstream();
+
+ /** Returns the pointer to the managed ostream. */
+ std::ostream* getManagedOstream() const { return d_managed; }
+
+ /** Returns the name of the ostream geing managed. */
+ virtual const char* getName() const = 0;
+
+ /**
+ * Set opens a file with filename, initializes the stream.
+ * If the opened ostream is marked as managed, this calls manage(stream).
+ * If the opened ostream is not marked as managed, this calls manage(NULL).
+ */
+ void set(const std::string& filename);
+
+ /** If this is associated with an option, return the string value. */
+ virtual std::string defaultSource() { return ""; }
+
+ protected:
+
+ /**
+ * Opens an ostream using OstreamOpener with the name getName() with the
+ * special cases added by addSpecialCases().
+ */
+ std::pair<bool, std::ostream*> open(const std::string& filename) const;
+
+ /**
+ * Updates the value of managed pointer. Whenever this changes,
+ * beforeRelease() is called on the old value.
+ */
+ void manage(std::ostream* new_managed_value);
+
+ /** Initializes an output stream. Not necessarily managed. */
+ virtual void initialize(std::ostream* outStream) {}
+
+ /** Adds special cases to an ostreamopener. */
+ virtual void addSpecialCases(OstreamOpener* opener) const {}
+
+ private:
+ std::ostream* d_managed;
+}; /* class ManagedOstream */
+
+class SetToDefaultSourceListener : public Listener {
+ public:
+ SetToDefaultSourceListener(ManagedOstream* managedOstream)
+ : d_managedOstream(managedOstream){}
+
+ virtual void notify() {
+ d_managedOstream->set(d_managedOstream->defaultSource());
+ }
+
+ private:
+ ManagedOstream* d_managedOstream;
+};
+
+/**
+ * This controls the memory associated with --dump-to.
+ * This is is assumed to recieve a set whenever diagnosticChannelName
+ * is updated.
+ */
+class ManagedDumpOStream : public ManagedOstream {
+ public:
+ ManagedDumpOStream(){}
+ ~ManagedDumpOStream();
+
+ virtual const char* getName() const { return "dump-to"; }
+ virtual std::string defaultSource() const;
+
+ protected:
+ /** Initializes an output stream. Not necessarily managed. */
+ virtual void initialize(std::ostream* outStream);
+
+ /** Adds special cases to an ostreamopener. */
+ virtual void addSpecialCases(OstreamOpener* opener) const;
+};/* class ManagedDumpOStream */
+
+/**
+ * When d_managedRegularChannel is non-null, it owns the memory allocated
+ * with the regular-output-channel. This is set when
+ * options::regularChannelName is set.
+ */
+class ManagedRegularOutputChannel : public ManagedOstream {
+ public:
+ ManagedRegularOutputChannel(){}
+
+ /** Assumes Options are in scope. */
+ ~ManagedRegularOutputChannel();
+
+ virtual const char* getName() const { return "regular-output-channel"; }
+ virtual std::string defaultSource() const;
+
+ protected:
+ /** Initializes an output stream. Not necessarily managed. */
+ virtual void initialize(std::ostream* outStream);
+
+ /** Adds special cases to an ostreamopener. */
+ virtual void addSpecialCases(OstreamOpener* opener) const;
+};/* class ManagedRegularOutputChannel */
+
+
+/**
+ * This controls the memory associated with diagnostic-output-channel.
+ * This is is assumed to recieve a set whenever options::diagnosticChannelName
+ * is updated.
+ */
+class ManagedDiagnosticOutputChannel : public ManagedOstream {
+ public:
+ ManagedDiagnosticOutputChannel(){}
+
+ /** Assumes Options are in scope. */
+ ~ManagedDiagnosticOutputChannel();
+
+ virtual const char* getName() const { return "diagnostic-output-channel"; }
+ virtual std::string defaultSource() const;
+
+ protected:
+ /** Initializes an output stream. Not necessarily managed. */
+ virtual void initialize(std::ostream* outStream);
+
+ /** Adds special cases to an ostreamopener. */
+ virtual void addSpecialCases(OstreamOpener* opener) const;
+};/* class ManagedRegularOutputChannel */
+
+/** This controls the memory associated with replay-log. */
+class ManagedReplayLogOstream : public ManagedOstream {
+ public:
+ ManagedReplayLogOstream();
+ ~ManagedReplayLogOstream();
+
+ std::ostream* getReplayLog() const { return d_replayLog; }
+ virtual const char* getName() const { return "replay-log"; }
+ virtual std::string defaultSource() const;
+
+ protected:
+ /** Initializes an output stream. Not necessarily managed. */
+ virtual void initialize(std::ostream* outStream);
+
+ /** Adds special cases to an ostreamopener. */
+ virtual void addSpecialCases(OstreamOpener* opener) const;
+
+ private:
+ std::ostream* d_replayLog;
+};/* class ManagedRegularOutputChannel */
+
+}/* CVC4 namespace */
+
+#endif /* __CVC4__MANAGED_OSTREAMS_H */
generated by cgit on debian on lair
contact matthew@masot.net with questions or feedback