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

com.github.sommeri.sourcemap.SourceMapSection Maven / Gradle / Ivy

Go to download

Less language is an extension of css and less4j compiles it into regular css. It adds several dynamic features into css: variables, expressions, nested rules. Less4j is a port. The original compiler was written in JavaScript and is called less.js. The less language is mostly defined in less.js documentation/issues and by what less.js actually do. Links to less.js: * home page: http://lesscss.org/ * source code & issues: https://github.com/cloudhead/less.js

There is a newer version: 1.17.2
Show newest version
/*
 * Copyright 2011 The Closure Compiler Authors.
 *
 * 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.github.sommeri.sourcemap;

/**
 * A class representing a partial source map.
 * @author [email protected] (John Lenz)
 */
public class SourceMapSection {

  /**
   * A URL for a valid source map file that represents a section of a generate
   * source file such as when multiple files are concatenated together.
   */
  private final String value;
  private final int line;
  private final int column;
  private final SectionType type;

  public static enum SectionType {
    URL,
    MAP
  }

  /**
   * @param sectionUrl The URL for the partial source map
   * @param line The number of lines into the file where the represented section
   *    starts.
   * @param column The number of characters into the line where the represented
   *    section starts.
   * @deprecated
   */
  @Deprecated
  public SourceMapSection(String sectionUrl, int line, int column) {
    this.type = SectionType.URL;
    this.value = sectionUrl;
    this.line = line;
    this.column = column;
  }

  private SourceMapSection(
      SectionType type, String value, int line, int column) {
    this.type = type;
    this.value = value;
    this.line = line;
    this.column = column;
  }

  public static SourceMapSection forMap(String value, int line, int column) {
    return new SourceMapSection(SectionType.MAP, value, line, column);
  }

  public static SourceMapSection forURL(String value, int line, int column) {
    return new SourceMapSection(SectionType.URL, value, line, column);
  }

  public SectionType getSectionType() {
    return this.type;
  }

  /**
   * @return the name of the map
   * @deprecated
   */
  @Deprecated
  public String getSectionUrl() {
    assert(type.equals(SectionType.URL));
    return value;
  }

  /**
   * @return the value that represents the map for this section.
   */
  public String getSectionValue() {
    return value;
  }

  /**
   * @return the starting line for this section
   */
  public int getLine() {
    return line;
  }

  /**
   * @return the column for this section
   */
  public int getColumn() {
    return column;
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy