/*
 * Copyright 2013 Google Inc.
 *
 * Use of this source code is governed by a BSD-style license that can be
 * found in the LICENSE file.
 */

#ifndef GrGLExtensions_DEFINED
#define GrGLExtensions_DEFINED

#include "GrGLInterface.h"
#include "SkString.h"
#include "SkTArray.h"

/**
 * This helper queries the current GL context for its extensions, remembers them, and can be
 * queried. It supports both glGetString- and glGetStringi-style extension string APIs and will
 * use the latter if it is available.
 */
class GrGLExtensions {
public:
    bool init(GrGLBinding binding, const GrGLInterface* iface) {
        SkASSERT(binding & iface->fBindingsExported);
        return this->init(binding, iface->fGetString, iface->fGetStringi, iface->fGetIntegerv);
    }
    /**
     * We sometimes need to use this class without having yet created a GrGLInterface. This version
     * of init expects that getString is always non-NULL while getIntegerv and getStringi are non-
     * NULL if on desktop GL with version 3.0 or higher. Otherwise it will fail.
     */
    bool init(GrGLBinding binding,
              GrGLGetStringProc getString,
              GrGLGetStringiProc getStringi,
              GrGLGetIntegervProc getIntegerv);

    /**
     * Queries whether an extension is present. This will fail if init() has not been called.
     */
    bool has(const char*) const;

    void reset() { fStrings.reset(); }

    void print(const char* sep = "\n") const;

private:
    SkTArray<SkString> fStrings;
};

#endif