diff options
| author | vvvv <[email protected]> | 2025-10-09 12:25:18 +0300 | 
|---|---|---|
| committer | vvvv <[email protected]> | 2025-10-09 12:57:17 +0300 | 
| commit | cb77d014972b2cdb27d2e6d979fc3a2772b27ad4 (patch) | |
| tree | 7f3bcd8ce71c6bd0f3ccc11e31b9f665475b819e /yql/essentials/minikql/computation/mkql_computation_node_holders_codegen.cpp | |
| parent | d58a8990d353b051c27e1069141117fdfde64358 (diff) | |
YQL-20086 minikql
commit_hash:e96f7390db5fcbe7e9f64f898141a263ad522daa
Diffstat (limited to 'yql/essentials/minikql/computation/mkql_computation_node_holders_codegen.cpp')
| -rw-r--r-- | yql/essentials/minikql/computation/mkql_computation_node_holders_codegen.cpp | 114 | 
1 files changed, 66 insertions, 48 deletions
| diff --git a/yql/essentials/minikql/computation/mkql_computation_node_holders_codegen.cpp b/yql/essentials/minikql/computation/mkql_computation_node_holders_codegen.cpp index 5757c21ece5..506e4573bcd 100644 --- a/yql/essentials/minikql/computation/mkql_computation_node_holders_codegen.cpp +++ b/yql/essentials/minikql/computation/mkql_computation_node_holders_codegen.cpp @@ -9,17 +9,19 @@ namespace NMiniKQL {  TContainerCacheOnContext::TContainerCacheOnContext(TComputationMutables& mutables)      : Index(mutables.CurValueIndex++)  { -    ++++mutables.CurValueIndex; +    ++ ++mutables.CurValueIndex;      mutables.CachedValues.insert(mutables.CachedValues.end(), {Index, Index + 1, Index + 2});  }  NUdf::TUnboxedValuePod TContainerCacheOnContext::NewArray(TComputationContext& ctx, ui64 size, NUdf::TUnboxedValue*& items) const { -    if (!size) +    if (!size) {          return ctx.HolderFactory.GetEmptyContainerLazy(); +    }      auto& index = ctx.MutableValues[Index]; -    if (index.IsInvalid()) +    if (index.IsInvalid()) {          index = NUdf::TUnboxedValuePod::Zero(); +    }      {          auto& val = ctx.MutableValues[Index + (index.Get<bool>() ? 1U : 2U)]; @@ -53,11 +55,17 @@ Value* GenerateCheckNotUniqueBoxed(Value* value, LLVMContext& context, Function*      block = have;      const auto half = CastInst::Create(Instruction::Trunc, value, Type::getInt64Ty(context), "half", block); -    const auto type = StructType::get(context, {PointerType::getUnqual(StructType::get(context)), Type::getInt32Ty(context), Type::getInt16Ty(context)}); +    const auto type = StructType::get(context, +                                      {PointerType::getUnqual(StructType::get(context)), +                                       Type::getInt32Ty(context), +                                       Type::getInt16Ty(context)});      const auto boxptr = CastInst::Create(Instruction::IntToPtr, half, PointerType::getUnqual(type), "boxptr", block); -    const auto cntptr = GetElementPtrInst::CreateInBounds(type, boxptr, {ConstantInt::get(Type::getInt32Ty(context), 0), ConstantInt::get(Type::getInt32Ty(context), 1)}, "cntptr", block); +    const auto cntptr = GetElementPtrInst::CreateInBounds( +        type, boxptr, +        {ConstantInt::get(Type::getInt32Ty(context), 0), ConstantInt::get(Type::getInt32Ty(context), 1)}, "cntptr", block);      const auto refs = new LoadInst(Type::getInt32Ty(context), cntptr, "refs", block); -    const auto many = CmpInst::Create(Instruction::ICmp, ICmpInst::ICMP_UGT, refs, ConstantInt::get(refs->getType(), 1U), "many", block); +    const auto many = CmpInst::Create(Instruction::ICmp, ICmpInst::ICMP_UGT, refs, +                                      ConstantInt::get(refs->getType(), 1U), "many", block);      result->addIncoming(many, block);      BranchInst::Create(done, block); @@ -65,7 +73,7 @@ Value* GenerateCheckNotUniqueBoxed(Value* value, LLVMContext& context, Function*      return result;  } -} +} // namespace  Value* TContainerCacheOnContext::GenNewArray(ui64 sz, Value* items, const TCodegenContext& ctx, BasicBlock*& block) const {      auto& context = ctx.Codegen.GetContext(); @@ -162,12 +170,14 @@ Value* TContainerCacheOnContext::GenNewArray(ui64 sz, Value* items, const TCodeg  }  #endif -class TEmptyNode : public TMutableCodegeneratorNode<TEmptyNode> { +class TEmptyNode: public TMutableCodegeneratorNode<TEmptyNode> {      typedef TMutableCodegeneratorNode<TEmptyNode> TBaseComputation; +  public:      TEmptyNode(TComputationMutables& mutables)          : TBaseComputation(mutables, EValueRepresentation::Boxed) -    {} +    { +    }      NUdf::TUnboxedValuePod DoCalculate(TComputationContext& ctx) const {          return ctx.HolderFactory.GetEmptyContainerLazy(); @@ -187,15 +197,18 @@ public:      }  #endif  private: -    void RegisterDependencies() const final {} +    void RegisterDependencies() const final { +    }  };  class TOptionalNode: public TDecoratorCodegeneratorNode<TOptionalNode> {      typedef TDecoratorCodegeneratorNode<TOptionalNode> TBaseComputation; +  public:      TOptionalNode(IComputationNode* itemNode)          : TBaseComputation(itemNode) -    {} +    { +    }      NUdf::TUnboxedValuePod DoCalculate(TComputationContext&, const NUdf::TUnboxedValuePod& value) const {          return value.MakeOptional(); @@ -210,6 +223,7 @@ public:  class TArrayNode: public TMutableCodegeneratorFallbackNode<TArrayNode> {      typedef TMutableCodegeneratorFallbackNode<TArrayNode> TBaseComputation; +  public:      TArrayNode(TComputationMutables& mutables, TComputationNodePtrVector&& valueNodes)          : TBaseComputation(mutables, EValueRepresentation::Boxed) @@ -219,7 +233,7 @@ public:      }      NUdf::TUnboxedValuePod DoCalculate(TComputationContext& ctx) const { -        NUdf::TUnboxedValue *items = nullptr; +        NUdf::TUnboxedValue* items = nullptr;          const auto result = Cache.NewArray(ctx, ValueNodes.size(), items);          if (!ValueNodes.empty()) {              Y_ABORT_UNLESS(items); @@ -233,8 +247,9 @@ public:  #ifndef MKQL_DISABLE_CODEGEN      Value* DoGenerateGetValue(const TCodegenContext& ctx, BasicBlock*& block) const { -        if (ValueNodes.size() > CodegenArraysFallbackLimit) +        if (ValueNodes.size() > CodegenArraysFallbackLimit) {              return TBaseComputation::DoGenerateGetValue(ctx, block); +        }          auto& context = ctx.Codegen.GetContext(); @@ -243,15 +258,17 @@ public:          const auto type = ArrayType::get(valType, ValueNodes.size());          const auto ptrType = PointerType::getUnqual(type);          /// TODO: how to get computation context or other workaround -        const auto itms = *Stateless_ || ctx.AlwaysInline ? -            new AllocaInst(ptrType, 0U, "itms", &ctx.Func->getEntryBlock().back()): -            new AllocaInst(ptrType, 0U, "itms", block); +        const auto itms = *Stateless_ || ctx.AlwaysInline +                              ? new AllocaInst(ptrType, 0U, "itms", &ctx.Func->getEntryBlock().back()) +                              : new AllocaInst(ptrType, 0U, "itms", block);          const auto result = Cache.GenNewArray(ValueNodes.size(), itms, ctx, block);          const auto itemsPtr = new LoadInst(ptrType, itms, "items", block);          ui32 i = 0U;          for (const auto node : ValueNodes) { -            const auto itemPtr = GetElementPtrInst::CreateInBounds(type, itemsPtr, {ConstantInt::get(idxType, 0), ConstantInt::get(idxType, i++)}, "item", block); +            const auto itemPtr = GetElementPtrInst::CreateInBounds( +                type, itemsPtr, +                {ConstantInt::get(idxType, 0), ConstantInt::get(idxType, i++)}, "item", block);              GetNodeValue(itemPtr, node, ctx, block);          }          return result; @@ -266,20 +283,23 @@ private:      const TContainerCacheOnContext Cache;  }; -class TVariantNode : public TMutableCodegeneratorNode<TVariantNode> { +class TVariantNode: public TMutableCodegeneratorNode<TVariantNode> {      typedef TMutableCodegeneratorNode<TVariantNode> TBaseComputation; +  public:      TVariantNode(TComputationMutables& mutables, IComputationNode* itemNode, ui32 index)          : TBaseComputation(mutables, EValueRepresentation::Any)          , ItemNode(itemNode)          , Index(index) -    {} +    { +    }      NUdf::TUnboxedValuePod DoCalculate(TComputationContext& ctx) const { -        if (auto item = ItemNode->GetValue(ctx); item.TryMakeVariant(Index)) +        if (auto item = ItemNode->GetValue(ctx); item.TryMakeVariant(Index)) {              return item.Release(); -        else +        } else {              return ctx.HolderFactory.CreateBoxedVariantHolder(item.Release(), Index); +        }      }  #ifndef MKQL_DISABLE_CODEGEN      Value* DoGenerateGetValue(const TCodegenContext& ctx, BasicBlock*& block) const { @@ -292,18 +312,19 @@ private:          DependsOn(ItemNode);      } -    IComputationNode *const ItemNode; +    IComputationNode* const ItemNode;      const ui32 Index;  };  class TDictNode: public TMutableComputationNode<TDictNode> {      typedef TMutableComputationNode<TDictNode> TBaseComputation; +  public:      TDictNode(TComputationMutables& mutables, -            std::vector<std::pair<IComputationNode*, IComputationNode*>>&& itemNodes, -            const TKeyTypes& types, bool isTuple, TType* encodedType, -            NUdf::IHash::TPtr hash, NUdf::IEquate::TPtr equate, -            NUdf::ICompare::TPtr compare, bool isSorted) +              std::vector<std::pair<IComputationNode*, IComputationNode*>>&& itemNodes, +              const TKeyTypes& types, bool isTuple, TType* encodedType, +              NUdf::IHash::TPtr hash, NUdf::IEquate::TPtr equate, +              NUdf::ICompare::TPtr compare, bool isSorted)          : TBaseComputation(mutables)          , ItemNodes(std::move(itemNodes))          , Types(types) @@ -313,7 +334,8 @@ public:          , Equate(equate)          , Compare(compare)          , IsSorted(isSorted) -    {} +    { +    }      NUdf::TUnboxedValuePod DoCalculate(TComputationContext& ctx) const {          TKeyPayloadPairVector items; @@ -333,22 +355,22 @@ public:              };              return ctx.HolderFactory.CreateDirectSortedDictHolder(filler, Types, IsTuple, EDictSortMode::RequiresSorting, -                true, EncodedType, Compare.Get(), Equate.Get()); +                                                                  true, EncodedType, Compare.Get(), Equate.Get());          } else {              THashedDictFiller filler = -                    [&items, &packer](TValuesDictHashMap& map) { -                        for (auto& value : items) { -                            auto key = std::move(value.first); -                            if (packer) { -                                key = MakeString(packer->Pack(key)); -                            } - -                            map.emplace(std::move(key), std::move(value.second)); +                [&items, &packer](TValuesDictHashMap& map) { +                    for (auto& value : items) { +                        auto key = std::move(value.first); +                        if (packer) { +                            key = MakeString(packer->Pack(key));                          } -                    }; + +                        map.emplace(std::move(key), std::move(value.second)); +                    } +                };              return ctx.HolderFactory.CreateDirectHashedDictHolder( -                    filler, Types, IsTuple, true, EncodedType, Hash.Get(), Equate.Get()); +                filler, Types, IsTuple, true, EncodedType, Hash.Get(), Equate.Get());          }      } @@ -379,18 +401,15 @@ TNodeFactory::TNodeFactory(TMemoryUsageInfo& memInfo, TComputationMutables& muta  {  } -IComputationNode* TNodeFactory::CreateEmptyNode() const -{ +IComputationNode* TNodeFactory::CreateEmptyNode() const {      return new TEmptyNode(Mutables);  } -IComputationNode* TNodeFactory::CreateOptionalNode(IComputationNode* item) const -{ +IComputationNode* TNodeFactory::CreateOptionalNode(IComputationNode* item) const {      return item ? new TOptionalNode(item) : CreateImmutableNode(NUdf::TUnboxedValuePod());  } -IComputationNode* TNodeFactory::CreateArrayNode(TComputationNodePtrVector&& values) const -{ +IComputationNode* TNodeFactory::CreateArrayNode(TComputationNodePtrVector&& values) const {      if (values.empty()) {          return new TEmptyNode(Mutables);      } @@ -399,10 +418,9 @@ IComputationNode* TNodeFactory::CreateArrayNode(TComputationNodePtrVector&& valu  }  IComputationNode* TNodeFactory::CreateDictNode( -        std::vector<std::pair<IComputationNode*, IComputationNode*>>&& items, -        const TKeyTypes& types, bool isTuple, TType* encodedType, -        NUdf::IHash::TPtr hash, NUdf::IEquate::TPtr equate, NUdf::ICompare::TPtr compare, bool isSorted) const -{ +    std::vector<std::pair<IComputationNode*, IComputationNode*>>&& items, +    const TKeyTypes& types, bool isTuple, TType* encodedType, +    NUdf::IHash::TPtr hash, NUdf::IEquate::TPtr equate, NUdf::ICompare::TPtr compare, bool isSorted) const {      if (items.empty()) {          return new TEmptyNode(Mutables);      } | 
