]> git.tdb.fi Git - libs/gl.git/blobdiff - source/glsl/compiler.h
Check the flat qualifier from the correct member
[libs/gl.git] / source / glsl / compiler.h
index 51b4f00a683059579157297c1ca9803e7aff9994..0db1ca400de7f017b2991e414dd3c0c331bc8a3d 100644 (file)
@@ -40,16 +40,13 @@ private:
        };
 
        Features features;
-       Module *module;
+       Module *module = 0;
        std::vector<std::string> imported_names;
-       bool compiled;
-       bool specialized;
+       bool compiled = false;
+       bool specialized = false;
        std::map<std::string, int> spec_values;
 
 public:
-       /** Creates a compiler using features from the current OpenGL context. */
-       Compiler();
-
        /** Creates a compiler targeting a specific set of features. */
        Compiler(const Features &);
 
@@ -91,7 +88,7 @@ public:
 
        /** Returns a combined SPIR-V binary for all shader stages.  The result is
        suitable for use with OpenGL or Vulkan. */
-       std::vector<UInt32> get_combined_spirv() const;
+       std::vector<std::uint32_t> get_combined_spirv() const;
 
        /** Returns a map of vertex attribute locations.  If the target GLSL version
        supports interface layouts, the map is empty (locations are included in the
@@ -112,13 +109,15 @@ public:
        source). */
        const std::map<std::string, unsigned> &get_uniform_block_bindings() const;
 
+       unsigned get_n_clip_distances() const;
+
        /** Returns the mapping of source indices to filenames.  Can be used to
        translate error messages. */
        const SourceMap &get_source_map() const;
 
        /** Returns a textual representation of the syntax tree for a shader stage.
        Intended for debugging purposes. */
-       std::string get_stage_debug(Stage::Type) const;
+       std::string get_stage_debug(Stage::Type, bool = false) const;
 
        /** Returns diagnostics from compilation.  The output is intended to be
        viewed by humans. */
@@ -126,13 +125,13 @@ public:
 
 private:
        /** Appends a module to the target, processing any imports found in it. */
-       void append_module(Module &, DataFile::Collection *);
+       void append_module(const Module &, ModuleCache &);
 
        /** Appends a single stage to the matching stage of the target. */
-       void append_stage(Stage &);
+       void append_stage(const Stage &);
 
        /// Imports a module by name and appends it to the target. */
-       void import(DataFile::Collection *, const std::string &);
+       void import(ModuleCache &, const std::string &);
 
        /** Generates any implicitly defines syntactic structures and resolves
        variables. */