From e0521498bcde9235ae5b20b4a83a1c37fb91574d Mon Sep 17 00:00:00 2001 From: Balazs Varga Date: Tue, 5 Nov 2024 09:41:16 +0100 Subject: Related: tdf#163736 - sc: Fix wrong nSearchMode (0) in vlookup For VLOOKUP nSearchMode was 0. So static_cast(nSearchMode) casts to a value which does not exist in SearchMode enum. That gives an "undefined behavior". Better to use the valid default forward search. (1) Change-Id: I1757b43073e13638704b96c4a9d036cb9a21e470 Reviewed-on: https://gerrit.libreoffice.org/c/core/+/176043 Reviewed-by: Balazs Varga Tested-by: Jenkins --- sc/source/core/tool/interpr1.cxx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/sc/source/core/tool/interpr1.cxx b/sc/source/core/tool/interpr1.cxx index 3f7ab08e712c..2f5656769ced 100644 --- a/sc/source/core/tool/interpr1.cxx +++ b/sc/source/core/tool/interpr1.cxx @@ -7825,7 +7825,7 @@ void ScInterpreter::CalculateLookup(bool bHLookup) else { ScAddress aResultPos( nCol1, nRow1, nTab1); - bFound = LookupQueryWithCache( aResultPos, aParam, refData, 0, SC_OPCODE_V_LOOKUP ); + bFound = LookupQueryWithCache( aResultPos, aParam, refData, 1 /*searchfwd*/, SC_OPCODE_V_LOOKUP ); nRow = aResultPos.Row(); nCol = nSpIndex; } -- cgit