/* Copyright (c) 2008 Google 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.google.gdata.data.projecthosting; import com.google.gdata.data.BaseEntry; import com.google.gdata.data.ExtensionProfile; import com.google.gdata.data.Link; import java.util.List; /** * Google Code Project Summary Entry. * * */ public class ProjectSummaryEntry extends BaseEntry<ProjectSummaryEntry> { /** * Default mutable constructor. */ public ProjectSummaryEntry() { super(); } /** * Constructs a new instance by doing a shallow copy of data from an existing * {@link BaseEntry} instance. * * @param sourceEntry source entry */ public ProjectSummaryEntry(BaseEntry<?> sourceEntry) { super(sourceEntry); } @Override public void declareExtensions(ExtensionProfile extProfile) { if (extProfile.isDeclared(ProjectSummaryEntry.class)) { return; } super.declareExtensions(extProfile); extProfile.declare(ProjectSummaryEntry.class, Description.class); extProfile.declare(ProjectSummaryEntry.class, IssuesLink.getDefaultDescription(false, true)); extProfile.declare(ProjectSummaryEntry.class, ProjectLabel.getDefaultDescription(false, true)); extProfile.declare(ProjectSummaryEntry.class, Repository.getDefaultDescription(false, true)); new Repository().declareExtensions(extProfile); } /** * Returns the description. * * @return description */ public Description getDescription() { return getExtension(Description.class); } /** * Sets the description. * * @param description description or <code>null</code> to reset */ public void setDescription(Description description) { if (description == null) { removeExtension(Description.class); } else { setExtension(description); } } /** * Returns whether it has the description. * * @return whether it has the description */ public boolean hasDescription() { return hasExtension(Description.class); } /** * Returns the project labels. * * @return project labels */ public List<ProjectLabel> getProjectLabels() { return getRepeatingExtension(ProjectLabel.class); } /** * Adds a new project label. * * @param projectLabel project label */ public void addProjectLabel(ProjectLabel projectLabel) { getProjectLabels().add(projectLabel); } /** * Returns whether it has the project labels. * * @return whether it has the project labels */ public boolean hasProjectLabels() { return hasRepeatingExtension(ProjectLabel.class); } /** * Returns the repositories. * * @return repositories */ public List<Repository> getRepositories() { return getRepeatingExtension(Repository.class); } /** * Adds a new repository. * * @param repository repository */ public void addRepository(Repository repository) { getRepositories().add(repository); } /** * Returns whether it has the repositories. * * @return whether it has the repositories */ public boolean hasRepositories() { return hasRepeatingExtension(Repository.class); } /** * Returns the link that provides the URI of a related link to the entry. * * @return Link that provides the URI of a related link to the entry or {@code * null} for none. */ public Link getRelatedLink() { return getLink(Link.Rel.RELATED, Link.Type.ATOM); } @Override protected void validate() { } @Override public String toString() { return "{ProjectSummaryEntry " + super.toString() + "}"; } }