All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.squarespace.less.parse.Parselet 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.parse;

import com.squarespace.less.LessException;
import com.squarespace.less.model.Node;


/**
 * A fragment of parsing logic that can be composed into a full
 * parser.  Parselet instances should have no private data, using
 * only the LessStream interface and any static utility methods
 * required.
 *
 * Breaking up the parser this way is for two reasons:
 *
 * 1. Mirroring the same parser structure as less.js. This simplifies
 *    implementing the language and keeping it compatible with
 *    upstream.
 *
 * 2. Writing parser unit tests which can focus completely on
 *    a specific part of the syntax without requiring a lot of
 *    boilerplate, e.g. writing a full mixin when you just want to
 *    test the guard syntax.  This enables more focused and
 *    efficient testing of many edge cases, improving coverage.
 */
public interface Parselet {

  Node parse(LessStream stm) throws LessException;

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy