/* 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.model.atom;
import com.google.gdata.model.Element;
import com.google.gdata.model.gd.GdAttributes;
import com.google.gdata.util.Namespaces;
/**
* The Kind class contains constants and static helper methods related to
* GData kind processing
*
*
*/
class Kinds {
/**
* Returns the GData kind of a target entity by checking for the
* {@code gd:kind} attribute or a kind {@link Category} element. If both
* are present, the kind attribute value will have precedence and be returned.
*
* @param source source feed or entry element to check
* @return kind value or {@code null} if no kind information is found.
*/
static String getElementKind(Element source) {
String term = source.getAttributeValue(GdAttributes.KIND);
if (term != null) {
return term;
}
for (Category category : source.getElements(Category.KEY)) {
if (Namespaces.gKind.equals(category.getScheme())) {
return category.getTerm();
}
}
return null;
}
// Not instantiable
private Kinds() {}
}