
io.sarl.api.naming.parser.ArtifactSchemeNameParser Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of api.naming Show documentation
Show all versions of api.naming Show documentation
Naming Library of the SARL SDK
The newest version!
/**
* $Id$
*
* SARL is an general-purpose agent programming language.
* More details on http://www.sarl.io
*
* Copyright (C) 2014-2024 SARL.io, the Original Authors and Main 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 io.sarl.api.naming.parser;
import io.sarl.api.naming.name.ArtifactName;
import io.sarl.lang.core.annotation.DefaultValue;
import io.sarl.lang.core.annotation.DefaultValueSource;
import io.sarl.lang.core.annotation.DefaultValueUse;
import io.sarl.lang.core.annotation.SarlElementType;
import io.sarl.lang.core.annotation.SarlSourceCode;
import io.sarl.lang.core.annotation.SarlSpecification;
import io.sarl.lang.core.annotation.SyntheticMember;
import java.net.URI;
import java.util.StringTokenizer;
import java.util.UUID;
import org.eclipse.xtext.xbase.lib.Pure;
import org.eclipse.xtext.xbase.lib.XbaseGenerated;
/**
* Parser of artifact names that is accepting URI-based syntax.
*
* The different types of names are:
* - {@code "artifact:[/]{0-2}artifactId[#fragmentName]"}
*
*
* @author Stéphane Galland
* @version api.naming 0.14.0 20241106-161408
* @mavengroupid io.sarl.sdk
* @mavenartifactid api.naming
* @since 0.12
*/
@SarlSpecification("0.14")
@SarlElementType(10)
@XbaseGenerated
@SuppressWarnings("all")
public class ArtifactSchemeNameParser extends AbstractSchemeNameParser {
/**
* Constructor.
*
* @optionalparam scheme the name scheme that is supported by this parser. By default it is {@link ArtifactName#SCHEME}.
*/
@DefaultValueSource
public ArtifactSchemeNameParser(@DefaultValue("io.sarl.api.naming.parser.ArtifactSchemeNameParser#NEW_0") final String scheme) {
super(scheme);
}
@Pure
@Override
public URI refactor(final URI name) {
return this.refactor(name, 1, 1);
}
@Pure
@Override
public ArtifactName decode(final URI name) {
String _path = name.getPath();
final StringTokenizer tokenizer = new StringTokenizer(_path, "/");
boolean _hasMoreTokens = tokenizer.hasMoreTokens();
if (_hasMoreTokens) {
final String token = tokenizer.nextToken();
UUID _fromString = UUID.fromString(token);
return new ArtifactName(name, _fromString);
}
return null;
}
/**
* Default value for the parameter scheme
*/
@Pure
@SyntheticMember
@SarlSourceCode("ArtifactName::SCHEME")
private static String $DEFAULT_VALUE$NEW_0() {
return ArtifactName.SCHEME;
}
/**
* Constructor.
*
* @optionalparam scheme the name scheme that is supported by this parser. By default it is {@link ArtifactName#SCHEME}.
*/
@DefaultValueUse("java.lang.String")
@SyntheticMember
public ArtifactSchemeNameParser() {
this($DEFAULT_VALUE$NEW_0());
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy