summaryrefslogtreecommitdiff
path: root/src/mbgl/programs
diff options
context:
space:
mode:
authorJohn Firebaugh <john.firebaugh@gmail.com>2017-03-09 07:53:02 -0800
committerJohn Firebaugh <john.firebaugh@gmail.com>2017-03-09 10:32:34 -0800
commitd5c2920104ea733b8ed417d2b9bdbade61b049cd (patch)
treeb3ca9606f83c348c2b5cbb471ca32cd9af564f73 /src/mbgl/programs
parentaf75736857213ff99145769883770d4b276a644a (diff)
downloadqtlocation-mapboxgl-d5c2920104ea733b8ed417d2b9bdbade61b049cd.tar.gz
[core] Extract and de-templatize several Program static methods
Diffstat (limited to 'src/mbgl/programs')
-rw-r--r--src/mbgl/programs/program.hpp31
1 files changed, 4 insertions, 27 deletions
diff --git a/src/mbgl/programs/program.hpp b/src/mbgl/programs/program.hpp
index ffad767c3a..8437e3a651 100644
--- a/src/mbgl/programs/program.hpp
+++ b/src/mbgl/programs/program.hpp
@@ -1,13 +1,9 @@
#pragma once
#include <mbgl/gl/program.hpp>
-#include <mbgl/programs/program_parameters.hpp>
#include <mbgl/programs/attributes.hpp>
#include <mbgl/style/paint_property.hpp>
-#include <mbgl/shaders/preludes.hpp>
-
-#include <sstream>
-#include <cassert>
+#include <mbgl/shaders/shaders.hpp>
namespace mbgl {
@@ -34,30 +30,11 @@ public:
ProgramType program;
Program(gl::Context& context, const ProgramParameters& programParameters)
- : program(context, vertexSource(programParameters), fragmentSource(programParameters))
+ : program(context,
+ shaders::vertexSource(programParameters, Shaders::vertexSource),
+ shaders::fragmentSource(programParameters, Shaders::fragmentSource))
{}
- static std::string pixelRatioDefine(const ProgramParameters& parameters) {
- std::ostringstream pixelRatioSS;
- pixelRatioSS.imbue(std::locale("C"));
- pixelRatioSS.setf(std::ios_base::showpoint);
- pixelRatioSS << parameters.pixelRatio;
- return std::string("#define DEVICE_PIXEL_RATIO ") + pixelRatioSS.str() + "\n";
- }
-
- static std::string fragmentSource(const ProgramParameters& parameters) {
- std::string source = pixelRatioDefine(parameters) + shaders::fragmentPrelude + Shaders::fragmentSource;
- if (parameters.overdraw) {
- assert(source.find("#ifdef OVERDRAW_INSPECTOR") != std::string::npos);
- source.replace(source.find_first_of('\n'), 1, "\n#define OVERDRAW_INSPECTOR\n");
- }
- return source;
- }
-
- static std::string vertexSource(const ProgramParameters& parameters) {
- return pixelRatioDefine(parameters) + shaders::vertexPrelude + Shaders::vertexSource;
- }
-
template <class DrawMode>
void draw(gl::Context& context,
DrawMode drawMode,