This is an automated email from the ASF dual-hosted git repository.

yiguolei pushed a commit to branch master
in repository https://gitbox.apache.org/repos/asf/doris.git


The following commit(s) were added to refs/heads/master by this push:
     new 29d4809c80 [BugFix](Array) fix DataTypeArray to_string use after free 
(#10640)
29d4809c80 is described below

commit 29d4809c80550ab7c864b415da1d95fb28b4793a
Author: lihangyu <15605149...@163.com>
AuthorDate: Wed Jul 6 18:18:00 2022 +0800

    [BugFix](Array) fix DataTypeArray to_string use after free (#10640)
    
    ColumnArray::convert_to_full_column_if_const override the base function
    and ColumnArray::create generate a temporary variable
---
 be/src/vec/data_types/data_type_array.cpp | 10 +++++-----
 1 file changed, 5 insertions(+), 5 deletions(-)

diff --git a/be/src/vec/data_types/data_type_array.cpp 
b/be/src/vec/data_types/data_type_array.cpp
index 40aa07011b..4c459ed4b8 100644
--- a/be/src/vec/data_types/data_type_array.cpp
+++ b/be/src/vec/data_types/data_type_array.cpp
@@ -96,8 +96,8 @@ void DataTypeArray::to_pb_column_meta(PColumnMeta* col_meta) 
const {
 }
 
 void DataTypeArray::to_string(const IColumn& column, size_t row_num, 
BufferWritable& ostr) const {
-    auto& data_column =
-            assert_cast<const 
ColumnArray&>(*column.convert_to_full_column_if_const().get());
+    auto ptr = column.convert_to_full_column_if_const();
+    auto& data_column = assert_cast<const ColumnArray&>(*ptr.get());
     auto& offsets = data_column.get_offsets();
 
     size_t offset = offsets[row_num - 1];
@@ -115,8 +115,8 @@ void DataTypeArray::to_string(const IColumn& column, size_t 
row_num, BufferWrita
 }
 
 std::string DataTypeArray::to_string(const IColumn& column, size_t row_num) 
const {
-    auto& data_column =
-            assert_cast<const 
ColumnArray&>(*column.convert_to_full_column_if_const().get());
+    auto ptr = column.convert_to_full_column_if_const();
+    auto& data_column = assert_cast<const ColumnArray&>(*ptr.get());
     auto& offsets = data_column.get_offsets();
 
     size_t offset = offsets[row_num - 1];
@@ -183,4 +183,4 @@ Status DataTypeArray::from_string(ReadBuffer& rb, IColumn* 
column) const {
     return Status::OK();
 }
 
-} // namespace doris::vectorized
\ No newline at end of file
+} // namespace doris::vectorized


---------------------------------------------------------------------
To unsubscribe, e-mail: commits-unsubscr...@doris.apache.org
For additional commands, e-mail: commits-h...@doris.apache.org

Reply via email to