/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You 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.
 */

/* $Id: DSCCommentBeginDocument.java 1681108 2015-05-22 13:26:12Z ssteiner $ */

package org.apache.xmlgraphics.ps.dsc.events;

import java.io.IOException;
import java.util.Iterator;
import java.util.List;

import org.apache.xmlgraphics.ps.DSCConstants;
import org.apache.xmlgraphics.ps.PSGenerator;
import org.apache.xmlgraphics.ps.PSResource;

Represents a %BeginDocument DSC comment.
/** * Represents a %BeginDocument DSC comment. */
public class DSCCommentBeginDocument extends AbstractDSCComment { private PSResource resource; private Float version; private String type;
Creates a new instance
/** * Creates a new instance */
public DSCCommentBeginDocument() { super(); }
Creates a new instance for a given PSResource instance
Params:
  • resource – the resource
/** * Creates a new instance for a given PSResource instance * @param resource the resource */
public DSCCommentBeginDocument(PSResource resource) { this.resource = resource; if (resource != null && !PSResource.TYPE_FILE.equals(resource.getType())) { throw new IllegalArgumentException("Resource must be of type 'file'"); } }
Creates a new instance for a given PSResource instance
Params:
  • resource – the resource
  • version – the version of the resource (or null)
  • type – the type of resource (or null)
/** * Creates a new instance for a given PSResource instance * @param resource the resource * @param version the version of the resource (or null) * @param type the type of resource (or null) */
public DSCCommentBeginDocument(PSResource resource, Float version, String type) { this(resource); this.version = version; this.type = type; }
Returns the resource version.
Returns:the resource version (or null if not applicable)
/** * Returns the resource version. * @return the resource version (or null if not applicable) */
public Float getVersion() { return this.version; }
Returns the resource type
Returns:the resource type (or null if not applicable)
/** * Returns the resource type * @return the resource type (or null if not applicable) */
public String getType() { return this.type; }
{@inheritDoc}
/** {@inheritDoc} */
public String getName() { return DSCConstants.BEGIN_DOCUMENT; }
Returns the associated PSResource.
Returns:the resource
/** * Returns the associated PSResource. * @return the resource */
public PSResource getResource() { return this.resource; }
{@inheritDoc}
/** {@inheritDoc} */
public boolean hasValues() { return true; }
{@inheritDoc}
/** {@inheritDoc} */
public void parseValue(String value) { List params = splitParams(value); Iterator iter = params.iterator(); String name = (String)iter.next(); this.resource = new PSResource(PSResource.TYPE_FILE, name); if (iter.hasNext()) { this.version = Float.valueOf(iter.next().toString()); this.type = null; if (iter.hasNext()) { this.type = (String)iter.next(); } } }
{@inheritDoc}
/** {@inheritDoc} */
public void generate(PSGenerator gen) throws IOException { List params = new java.util.ArrayList(); params.add(getResource().getName()); if (getVersion() != null) { params.add(getVersion()); if (getType() != null) { params.add(getType()); } } gen.writeDSCComment(getName(), params.toArray()); } }