com.squarespace.less.model.MixinParams Maven / Gradle / Ivy
/**
* Copyright (c) 2014 SQUARESPACE, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.squarespace.less.model;
import static com.squarespace.less.core.LessUtils.safeEquals;
import java.util.List;
import com.squarespace.less.LessException;
import com.squarespace.less.core.Buffer;
import com.squarespace.less.core.LessUtils;
import com.squarespace.less.exec.ExecEnv;
/**
* Represents all parameters for a {@link Mixin} definition.
*/
public class MixinParams extends BaseNode {
/**
* List of parameters in this group.
*/
protected List params;
/**
* Whether the {@link Mixin} is variadic.
*/
protected boolean variadic;
/**
* Number of required parameters.
*/
protected int required;
/**
* Indicates at least one of the parameters needs to be evaluated.
*/
protected boolean evaluate;
/**
* Indicates at least one of the parameters is named.
*/
protected boolean hasNamed;
/**
* Appends a parameter to the list, and sets our internal state based on its
* properties.
*/
public void add(Parameter param) {
params = LessUtils.initList(params, 3);
params.add(param);
variadic |= param.variadic();
Node paramValue = param.value();
if (!param.variadic() && (param.name() == null || (param.name() != null && paramValue == null))) {
required++;
}
if (paramValue != null) {
evaluate |= paramValue.needsEval();
}
hasNamed |= param.name() != null;
}
/**
* List of parameters.
*/
public List params() {
return LessUtils.safeList(params);
}
/**
* Number of parameters.
*/
public int arity() {
return params().size();
}
/**
* Number of required parameters.
*/
public int required() {
return required;
}
/**
* Whether the {@link Mixin} is variadic.
*/
public boolean variadic() {
return variadic;
}
/**
* Indicates whether at least one parameter is named.
*/
public boolean hasNamed() {
return hasNamed;
}
/**
* Convert the named parameters into a block for variable resolution.
*/
public GenericBlock toBlock(ExecEnv env) {
if (params == null || !hasNamed) {
return null;
}
Block block = new Block();
for (Parameter param : params) {
if (param.name() != null && param.value() != null) {
block.appendNode(env.context().nodeBuilder().buildDefinition(param.name(), param.value()));
}
}
return new GenericBlock(block);
}
/**
* See {@link Node#type()}
*/
@Override
public NodeType type() {
return NodeType.MIXIN_PARAMS;
}
/**
* See {@link Node#needsEval()}
*/
@Override
public boolean needsEval() {
return evaluate;
}
/**
* See {@link Node#eval(ExecEnv)}
*/
@Override
public Node eval(ExecEnv env) throws LessException {
if (!needsEval()) {
return this;
}
MixinParams result = new MixinParams();
for (Parameter param : params()) {
result.add((Parameter)param.eval(env));
}
return result;
}
/**
* See {@link Node#repr()}
*/
@Override
public void repr(Buffer buf) {
if (params == null) {
return;
}
int size = params.size();
for (int i = 0; i < size; i++) {
if (i > 0) {
buf.append(", ");
}
params.get(i).repr(buf);
}
}
/**
* See {@link Node#modelRepr(Buffer)}
*/
@Override
public void modelRepr(Buffer buf) {
typeRepr(buf);
posRepr(buf);
buf.incrIndent().append('\n');
if (params == null || params.isEmpty()) {
buf.indent().append("");
} else {
ReprUtils.modelRepr(buf, "\n", true, params);
}
buf.decrIndent();
}
@Override
public boolean equals(Object obj) {
return (obj instanceof MixinParams) ? safeEquals(params, ((MixinParams)obj).params) : false;
}
@Override
public int hashCode() {
return super.hashCode();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy