git: 34796ebc1db2 - main - sysutils/lnav: attempt to unbreak the build on 32-bit architectures

Alexey Dokuchaev danfe at FreeBSD.org
Sat Jun 19 14:47:19 UTC 2021


The branch main has been updated by danfe:

URL: https://cgit.FreeBSD.org/ports/commit/?id=34796ebc1db2aecdc58dde0774b7280fe2959543

commit 34796ebc1db2aecdc58dde0774b7280fe2959543
Author:     Alexey Dokuchaev <danfe at FreeBSD.org>
AuthorDate: 2021-06-19 14:44:18 +0000
Commit:     Alexey Dokuchaev <danfe at FreeBSD.org>
CommitDate: 2021-06-19 14:44:52 +0000

    sysutils/lnav: attempt to unbreak the build on 32-bit architectures
    
    Obtained from:  upstream (dfd18a4be5fd5e5378f44bef81bcc6cca4ac4a76)
---
 sysutils/lnav/Makefile                   |  3 ---
 sysutils/lnav/files/patch-src_logfile.cc | 37 ++++++++++++++++++++++++++++++++
 2 files changed, 37 insertions(+), 3 deletions(-)

diff --git a/sysutils/lnav/Makefile b/sysutils/lnav/Makefile
index 49e2f3b8d985..e06fb260aa31 100644
--- a/sysutils/lnav/Makefile
+++ b/sysutils/lnav/Makefile
@@ -10,9 +10,6 @@ COMMENT=	Terminal based log file navigator
 
 LICENSE=	BSD2CLAUSE
 
-BROKEN_i386=	fails to build: error: non-constant-expression cannot be narrowed
-BROKEN_powerpc=	fails to build: error: non-constant-expression cannot be narrowed
-
 LIB_DEPENDS=	libpcrecpp.so:devel/pcre
 
 USES=		autoreconf compiler:c++14-lang gmake ncurses readline sqlite tar:bz2
diff --git a/sysutils/lnav/files/patch-src_logfile.cc b/sysutils/lnav/files/patch-src_logfile.cc
new file mode 100644
index 000000000000..fbad7c3c686e
--- /dev/null
+++ b/sysutils/lnav/files/patch-src_logfile.cc
@@ -0,0 +1,37 @@
+--- src/logfile.cc.orig	2020-09-09 16:17:12 UTC
++++ src/logfile.cc
+@@ -323,10 +323,13 @@ logfile::rebuild_result_t logfile::rebuild_index()
+ 
+             this->lf_line_buffer.clear();
+             if (!this->lf_index.empty()) {
+-                off_t check_line_off = this->lf_index.back().get_offset();
++                auto last_line = this->lf_index.end();
++                --last_line;
++                off_t check_line_off = last_line->get_offset();
++                auto last_length = ssize_t(this->line_length(last_line, false));
+ 
+                 auto read_result = this->lf_line_buffer.read_range({
+-                    check_line_off, this->lf_index_size - check_line_off
++                    check_line_off, last_length
+                 });
+ 
+                 if (read_result.isErr()) {
+@@ -553,7 +556,7 @@ filesystem::path logfile::get_path() const
+ 
+ size_t logfile::line_length(logfile::iterator ll, bool include_continues)
+ {
+-    iterator next_line = ll;
++    auto next_line = ll;
+     size_t retval;
+ 
+     if (!include_continues && this->lf_next_line_cache) {
+@@ -570,6 +573,9 @@ size_t logfile::line_length(logfile::iterator ll, bool
+ 
+     if (next_line == this->end()) {
+         retval = this->lf_index_size - ll->get_offset();
++        if (retval > line_buffer::MAX_LINE_BUFFER_SIZE) {
++            retval = line_buffer::MAX_LINE_BUFFER_SIZE;
++        }
+         if (retval > 0 && !this->lf_partial_line) {
+             retval -= 1;
+         }


More information about the dev-commits-ports-all mailing list