Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(748)

Unified Diff: src/sksl/ir/SkSLVarDeclaration.h

Issue 2312233002: refactored SkSL VarDeclaration handling (Closed)
Patch Set: fixed nits Created 4 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « src/sksl/ir/SkSLStatement.h ('k') | src/sksl/ir/SkSLVarDeclarationStatement.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: src/sksl/ir/SkSLVarDeclaration.h
diff --git a/src/sksl/ir/SkSLVarDeclaration.h b/src/sksl/ir/SkSLVarDeclaration.h
index ca3c7f95b270465b661abf4962e8196b74d27e77..e64a874d69df2d9a66bd5055301ba5d5c848829e 100644
--- a/src/sksl/ir/SkSLVarDeclaration.h
+++ b/src/sksl/ir/SkSLVarDeclaration.h
@@ -5,8 +5,8 @@
* found in the LICENSE file.
*/
-#ifndef SKSL_VARDECLARATION
-#define SKSL_VARDECLARATION
+#ifndef SKSL_VARDECLARATIONS
+#define SKSL_VARDECLARATIONS
#include "SkSLExpression.h"
#include "SkSLStatement.h"
@@ -15,51 +15,65 @@
namespace SkSL {
/**
- * A variable declaration, which may consist of multiple individual variables. For instance
- * 'int x, y = 1, z[4][2];' is a single VarDeclaration. This declaration would have a base type of
- * 'int', names ['x', 'y', 'z'], sizes of [[], [], [4, 2]], and values of [null, 1, null].
+ * A single variable declaration within a var declaration statement. For instance, the statement
+ * 'int x = 2, y[3];' is a VarDeclarations statement containing two individual VarDeclaration
+ * instances.
*/
-struct VarDeclaration : public ProgramElement {
- VarDeclaration(Position position, const Type* baseType, std::vector<const Variable*> vars,
- std::vector<std::vector<std::unique_ptr<Expression>>> sizes,
- std::vector<std::unique_ptr<Expression>> values)
+struct VarDeclaration {
+ VarDeclaration(const Variable* var,
+ std::vector<std::unique_ptr<Expression>> sizes,
+ std::unique_ptr<Expression> value)
+ : fVar(var)
+ , fSizes(std::move(sizes))
+ , fValue(std::move(value)) {}
+
+ std::string description() const {
+ std::string result = fVar->fName;
+ for (const auto& size : fSizes) {
+ if (size) {
+ result += "[" + size->description() + "]";
+ } else {
+ result += "[]";
+ }
+ }
+ if (fValue) {
+ result += " = " + fValue->description();
+ }
+ return result;
+ }
+
+ const Variable* fVar;
+ std::vector<std::unique_ptr<Expression>> fSizes;
+ std::unique_ptr<Expression> fValue;
+};
+
+/**
+ * A variable declaration statement, which may consist of one or more individual variables.
+ */
+struct VarDeclarations : public ProgramElement {
+ VarDeclarations(Position position, const Type* baseType,
+ std::vector<VarDeclaration> vars)
: INHERITED(position, kVar_Kind)
, fBaseType(*baseType)
- , fVars(std::move(vars))
- , fSizes(std::move(sizes))
- , fValues(std::move(values)) {}
+ , fVars(std::move(vars)) {}
std::string description() const override {
- std::string result = fVars[0]->fModifiers.description();
- const Type* baseType = &fVars[0]->fType;
- while (baseType->kind() == Type::kArray_Kind) {
- baseType = &baseType->componentType();
+ if (!fVars.size()) {
+ return "";
}
- result += baseType->description();
- std::string separator = " ";
- for (size_t i = 0; i < fVars.size(); i++) {
+ std::string result = fVars[0].fVar->fModifiers.description() + fBaseType.description() +
+ " ";
+ std::string separator = "";
+ for (const auto& var : fVars) {
result += separator;
separator = ", ";
- result += fVars[i]->fName;
- for (size_t j = 0; j < fSizes[i].size(); j++) {
- if (fSizes[i][j]) {
- result += "[" + fSizes[i][j]->description() + "]";
- } else {
- result += "[]";
- }
- }
- if (fValues[i]) {
- result += " = " + fValues[i]->description();
- }
+ result += var.description();
}
- result += ";";
return result;
}
const Type& fBaseType;
- const std::vector<const Variable*> fVars;
- const std::vector<std::vector<std::unique_ptr<Expression>>> fSizes;
- const std::vector<std::unique_ptr<Expression>> fValues;
+ const std::vector<VarDeclaration> fVars;
typedef ProgramElement INHERITED;
};
« no previous file with comments | « src/sksl/ir/SkSLStatement.h ('k') | src/sksl/ir/SkSLVarDeclarationStatement.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698