summaryrefslogtreecommitdiffstats
path: root/src/textfile_sub_source.hh
diff options
context:
space:
mode:
Diffstat (limited to 'src/textfile_sub_source.hh')
-rw-r--r--src/textfile_sub_source.hh173
1 files changed, 173 insertions, 0 deletions
diff --git a/src/textfile_sub_source.hh b/src/textfile_sub_source.hh
new file mode 100644
index 0000000..724f7c7
--- /dev/null
+++ b/src/textfile_sub_source.hh
@@ -0,0 +1,173 @@
+/**
+ * Copyright (c) 2007-2012, Timothy Stack
+ *
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are met:
+ *
+ * * Redistributions of source code must retain the above copyright notice, this
+ * list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above copyright notice,
+ * this list of conditions and the following disclaimer in the documentation
+ * and/or other materials provided with the distribution.
+ * * Neither the name of Timothy Stack nor the names of its contributors
+ * may be used to endorse or promote products derived from this software
+ * without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ''AS IS'' AND ANY
+ * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
+ * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
+ * DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY
+ * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
+ * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
+ * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
+ * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#ifndef textfile_sub_source_hh
+#define textfile_sub_source_hh
+
+#include <deque>
+#include <unordered_map>
+
+#include "filter_observer.hh"
+#include "logfile.hh"
+#include "plain_text_source.hh"
+#include "textview_curses.hh"
+
+class textfile_sub_source
+ : public text_sub_source
+ , public vis_location_history
+ , public text_anchors {
+public:
+ using file_iterator = std::deque<std::shared_ptr<logfile>>::iterator;
+
+ textfile_sub_source() { this->tss_supports_filtering = true; }
+
+ ~textfile_sub_source() override = default;
+
+ bool empty() const { return this->tss_files.empty(); }
+
+ size_t size() const { return this->tss_files.size(); }
+
+ size_t text_line_count() override;
+
+ size_t text_line_width(textview_curses& curses) override
+ {
+ return this->tss_files.empty()
+ ? 0
+ : this->current_file()->get_longest_line_length();
+ }
+
+ void text_value_for_line(textview_curses& tc,
+ int line,
+ std::string& value_out,
+ line_flags_t flags) override;
+
+ void text_attrs_for_line(textview_curses& tc,
+ int row,
+ string_attrs_t& value_out) override;
+
+ size_t text_size_for_line(textview_curses& tc,
+ int line,
+ line_flags_t flags) override;
+
+ std::shared_ptr<logfile> current_file() const
+ {
+ if (this->tss_files.empty()) {
+ return nullptr;
+ }
+
+ return this->tss_files.front();
+ }
+
+ std::string text_source_name(const textview_curses& tv) override
+ {
+ if (this->tss_files.empty()) {
+ return "";
+ }
+
+ return this->tss_files.front()->get_filename();
+ }
+
+ void to_front(const std::shared_ptr<logfile>& lf);
+
+ bool to_front(const std::string& filename);
+
+ void set_top_from_off(file_off_t off);
+
+ void rotate_left();
+
+ void rotate_right();
+
+ void remove(const std::shared_ptr<logfile>& lf);
+
+ void push_back(const std::shared_ptr<logfile>& lf);
+
+ class scan_callback {
+ public:
+ virtual void closed_files(
+ const std::vector<std::shared_ptr<logfile>>& files)
+ = 0;
+ virtual void promote_file(const std::shared_ptr<logfile>& lf) = 0;
+ virtual void scanned_file(const std::shared_ptr<logfile>& lf) = 0;
+ };
+
+ bool rescan_files(scan_callback& callback,
+ nonstd::optional<ui_clock::time_point> deadline
+ = nonstd::nullopt);
+
+ void text_filters_changed() override;
+
+ int get_filtered_count() const override;
+
+ int get_filtered_count_for(size_t filter_index) const override;
+
+ text_format_t get_text_format() const override;
+
+ nonstd::optional<location_history*> get_location_history() override
+ {
+ return this;
+ }
+
+ void text_crumbs_for_line(int line,
+ std::vector<breadcrumb::crumb>& crumbs) override;
+
+ nonstd::optional<vis_line_t> row_for_anchor(const std::string& id) override;
+
+ nonstd::optional<std::string> anchor_for_row(vis_line_t vl) override;
+
+ std::unordered_set<std::string> get_anchors() override;
+
+ void quiesce() override;
+
+private:
+ void detach_observer(std::shared_ptr<logfile> lf)
+ {
+ auto* lfo = (line_filter_observer*) lf->get_logline_observer();
+ lf->set_logline_observer(nullptr);
+ delete lfo;
+ }
+
+ struct rendered_file {
+ time_t rf_mtime;
+ file_ssize_t rf_file_size;
+ std::unique_ptr<plain_text_source> rf_text_source;
+ };
+
+ struct metadata_state {
+ time_t ms_mtime;
+ file_ssize_t ms_file_size;
+ lnav::document::metadata ms_metadata;
+ };
+
+ std::deque<std::shared_ptr<logfile>> tss_files;
+ std::deque<std::shared_ptr<logfile>> tss_hidden_files;
+ std::unordered_map<std::string, rendered_file> tss_rendered_files;
+ std::unordered_map<std::string, metadata_state> tss_doc_metadata;
+};
+
+#endif