aboutsummaryrefslogtreecommitdiffhomepage
path: root/include/gpu/GrCustomStage.h
blob: a94cd5aaa0d78f09672a07647c6e44e847009481 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
/*
 * Copyright 2012 Google Inc.
 *
 * Use of this source code is governed by a BSD-style license that can be
 * found in the LICENSE file.
 */

#ifndef GrCustomStage_DEFINED
#define GrCustomStage_DEFINED

#include "GrRefCnt.h"
#include "GrNoncopyable.h"
#include "GrProgramStageFactory.h"

class GrContext;

/** Provides custom vertex shader, fragment shader, uniform data for a
    particular stage of the Ganesh shading pipeline. 
    Subclasses must have a function that produces a human-readable name:
        static const char* Name();
  */
class GrCustomStage : public GrRefCnt {

public:
    SK_DECLARE_INST_COUNT(GrCustomStage)

    typedef GrProgramStageFactory::StageKey StageKey;

    GrCustomStage();
    virtual ~GrCustomStage();

    /** If given an input texture that is/is not opaque, is this
        stage guaranteed to produce an opaque output? */
    virtual bool isOpaque(bool inputTextureIsOpaque) const;

    /** This object, besides creating back-end-specific helper
        objects, is used for run-time-type-identification. The factory should be
        an instance of templated class, GrTProgramStageFactory. It is templated
        on the subclass of GrCustomStage. The subclass must have a nested type
        (or typedef) named GLProgramStage which will be the subclass of
        GrGLProgramStage created by the factory.

        Example:
        class MyCustomStage : public GrCustomStage {
        ...
            virtual const GrProgramStageFactory& getFactory() const 
                                                            SK_OVERRIDE {
                return GrTProgramStageFactory<MyCustomStage>::getInstance();
            }
        ...
        };
     */
    virtual const GrProgramStageFactory& getFactory() const = 0;

    /** Returns true if the other custom stage will generate identical output.
        Must only be called if the two are already known to be of the
        same type (i.e.  they return the same value from getFactory()).

        Equality is not the same thing as equivalence.
        To test for equivalence (that they will generate the same
        shader code, but may have different uniforms), check equality
        of the stageKey produced by the GrProgramStageFactory:
        a.getFactory().genStageKey(a) == b.getFactory().genStageKey(b). */
    virtual bool isEqual(const GrCustomStage&) const = 0;

     /** Human-meaningful string to identify this effect; may be embedded
         in generated shader code. */
    const char* name() const { return this->getFactory().name(); }

private:

    typedef GrRefCnt INHERITED;
};

#endif