You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

64 lines
1.4 KiB

/*
* Copyright 2021 Google LLC.
*
* Use of this source code is governed by a BSD-style license that can be
* found in the LICENSE file.
*/
#ifndef SKSL_DSL_CASE
#define SKSL_DSL_CASE
#include "include/private/SkSLDefines.h"
#include "include/sksl/DSLExpression.h"
#include "include/sksl/DSLStatement.h"
#include <memory>
namespace SkSL {
class Statement;
namespace dsl {
class DSLCase {
public:
// An empty expression means 'default:'.
template<class... Statements>
DSLCase(DSLExpression value, Statements... statements)
: fValue(std::move(value)) {
fStatements.reserve_back(sizeof...(statements));
// in C++17, we could just do:
// (fStatements.push_back(DSLStatement(std::move(statements)).release()), ...);
int unused[] =
{0,
(static_cast<void>(fStatements.push_back(DSLStatement(std::move(statements)).release())),
0)...};
static_cast<void>(unused);
}
DSLCase(DSLExpression value, SkTArray<DSLStatement> statements);
DSLCase(DSLExpression value, SkSL::StatementArray statements);
DSLCase(DSLCase&&);
~DSLCase();
void append(DSLStatement stmt);
private:
DSLExpression fValue;
SkSL::StatementArray fStatements;
friend class DSLCore;
template<class... Cases>
friend DSLPossibleStatement Switch(DSLExpression value, Cases... cases);
};
} // namespace dsl
} // namespace SkSL
#endif