Edit

kc3-lang/angle/src/compiler/translator/PoolAlloc.cpp

Branch :

  • Show log

    Commit

  • Author : Yuly Novikov
    Date : 2020-02-14 16:23:28
    Hash : bb7534ee
    Message : Use ASSERT() instead of assert() when possible. Since ASSERT() works in Release builds. Left assert() in a few places where calling a function may not be safe. Bug: angleproject:4396 Change-Id: Ic75a3d41d846e327097f8c37fe2336dcd3be6cb8 Reviewed-on: https://chromium-review.googlesource.com/c/angle/angle/+/2057745 Reviewed-by: Jamie Madill <jmadill@chromium.org> Commit-Queue: Yuly Novikov <ynovikov@chromium.org>

  • src/compiler/translator/PoolAlloc.cpp
  • //
    // Copyright 2002 The ANGLE Project Authors. All rights reserved.
    // Use of this source code is governed by a BSD-style license that can be
    // found in the LICENSE file.
    //
    
    #include "compiler/translator/PoolAlloc.h"
    
    #include "common/debug.h"
    #include "common/tls.h"
    
    TLSIndex PoolIndex = TLS_INVALID_INDEX;
    
    bool InitializePoolIndex()
    {
        ASSERT(PoolIndex == TLS_INVALID_INDEX);
    
        PoolIndex = CreateTLSIndex();
        return PoolIndex != TLS_INVALID_INDEX;
    }
    
    void FreePoolIndex()
    {
        ASSERT(PoolIndex != TLS_INVALID_INDEX);
    
        DestroyTLSIndex(PoolIndex);
        PoolIndex = TLS_INVALID_INDEX;
    }
    
    angle::PoolAllocator *GetGlobalPoolAllocator()
    {
        ASSERT(PoolIndex != TLS_INVALID_INDEX);
        return static_cast<angle::PoolAllocator *>(GetTLSValue(PoolIndex));
    }
    
    void SetGlobalPoolAllocator(angle::PoolAllocator *poolAllocator)
    {
        ASSERT(PoolIndex != TLS_INVALID_INDEX);
        SetTLSValue(PoolIndex, poolAllocator);
    }