
io.sarl.api.naming.name.BehaviorName 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.name;
import io.sarl.lang.core.Behavior;
import io.sarl.lang.core.annotation.PrivateAPI;
import io.sarl.lang.core.annotation.SarlElementType;
import io.sarl.lang.core.annotation.SarlSpecification;
import io.sarl.lang.core.annotation.SyntheticMember;
import java.net.URI;
import java.util.Objects;
import java.util.UUID;
import org.eclipse.xtend.lib.annotations.Accessors;
import org.eclipse.xtext.xbase.lib.Pure;
import org.eclipse.xtext.xbase.lib.XbaseGenerated;
/**
* This class represents a behavior name.
*
* The different components of a behavior name are:
* - {@code contextId} (optional) : the identifier of the context in which the agent is located.
* If it is {@code null}, the the {@code spaceId} component is equal to {@code null}.
* - {@code spaceId} (optional) : the identifier of the space in which the agent is registered.
* - {@code agentId} (mandatory) : the identifier of the agent.
* - {@code behaviorType} (mandatory) : the fully qualified name of the behavior type.
* - {@code behaviorIndex} (optional) : the index of the behavior to point out when multiple
* behavior instances of the same type are defined in the agent.
*
*
* @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 BehaviorName extends SarlName {
/**
* Scheme for behaviors.
*/
public static final String SCHEME = "behavior";
@Accessors
private final UUID contextId;
@Accessors
private final UUID spaceId;
@Accessors
private final UUID agentId;
@Accessors
private final Class extends Behavior> behaviorType;
@Accessors
private final int behaviorIndex;
/**
* Constructor.
*
* @param uri the uri of the context.
* @param contextId the identifier of the context.
* @param spaceId the identifier of the space.
* @param agentId the identifier of the agent.
* @param behaviorType the type of the behavior.
* @param behaviorIndex the index of the behavior in the list of behaviors.
*/
@PrivateAPI
public BehaviorName(final URI uri, final UUID contextId, final UUID spaceId, final UUID agentId, final Class extends Behavior> behaviorType, final int behaviorIndex) {
super(uri);
this.contextId = contextId;
this.spaceId = spaceId;
this.agentId = agentId;
this.behaviorType = behaviorType;
this.behaviorIndex = behaviorIndex;
}
@Override
@Pure
@SyntheticMember
public boolean equals(final Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (getClass() != obj.getClass())
return false;
BehaviorName other = (BehaviorName) obj;
if (!Objects.equals(this.contextId, other.contextId))
return false;
if (!Objects.equals(this.spaceId, other.spaceId))
return false;
if (!Objects.equals(this.agentId, other.agentId))
return false;
if (other.behaviorIndex != this.behaviorIndex)
return false;
return super.equals(obj);
}
@Override
@Pure
@SyntheticMember
public int hashCode() {
int result = super.hashCode();
final int prime = 31;
result = prime * result + Objects.hashCode(this.contextId);
result = prime * result + Objects.hashCode(this.spaceId);
result = prime * result + Objects.hashCode(this.agentId);
result = prime * result + Integer.hashCode(this.behaviorIndex);
return result;
}
@Override
@Pure
@SyntheticMember
public BehaviorName clone() {
try {
return (BehaviorName) super.clone();
} catch (Throwable exception) {
throw new Error(exception);
}
}
@SyntheticMember
private static final long serialVersionUID = -183318694L;
@Pure
public UUID getContextId() {
return this.contextId;
}
@Pure
public UUID getSpaceId() {
return this.spaceId;
}
@Pure
public UUID getAgentId() {
return this.agentId;
}
@Pure
public Class extends Behavior> getBehaviorType() {
return this.behaviorType;
}
@Pure
public int getBehaviorIndex() {
return this.behaviorIndex;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy