1 /* ***** BEGIN LICENSE BLOCK *****
  2  * Version: MPL 1.1/GPL 2.0/LGPL 2.1
  3  *
  4  * The contents of this file are subject to the Mozilla Public License Version
  5  * 1.1 (the "License"); you may not use this file except in compliance with
  6  * the License. You may obtain a copy of the License at
  7  * http://www.mozilla.org/MPL/
  8  *
  9  * Software distributed under the License is distributed on an "AS IS" basis,
 10  * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
 11  * for the specific language governing rights and limitations under the
 12  * License.
 13  *
 14  * The Original Code is gContactSync.
 15  *
 16  * The Initial Developer of the Original Code is
 17  * Josh Geenen <gcontactsync@pirules.org>.
 18  * Portions created by the Initial Developer are Copyright (C) 2008-2009
 19  * the Initial Developer. All Rights Reserved.
 20  *
 21  * Contributor(s):
 22  *
 23  * Alternatively, the contents of this file may be used under the terms of
 24  * either the GNU General Public License Version 2 or later (the "GPL"), or
 25  * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
 26  * in which case the provisions of the GPL or the LGPL are applicable instead
 27  * of those above. If you wish to allow use of your version of this file only
 28  * under the terms of either the GPL or the LGPL, and not to allow others to
 29  * use your version of this file under the terms of the MPL, indicate your
 30  * decision by deleting the provisions above and replace them with the notice
 31  * and other provisions required by the GPL or the LGPL. If you do not delete
 32  * the provisions above, a recipient may use your version of this file under
 33  * the terms of any one of the MPL, the GPL or the LGPL.
 34  *
 35  * ***** END LICENSE BLOCK ***** */
 36 
 37 if (!com) var com = {}; // A generic wrapper variable
 38 // A wrapper for all GCS functions and variables
 39 if (!com.gContactSync) com.gContactSync = {};
 40 
 41 /**
 42  * A simple class for storing information about how Google represents a contact
 43  * in XML.
 44  * @param aType       {string} The "type" of contact, as found in gdata.types.
 45  * @param aTagName    {string} The tag name of the element.
 46  * @param aNamespace  {Namespace} The Namespace object that contains the
 47  *                                element.
 48  * @param aValidTypes {array} The different types allowed, as an array, for
 49  *                            example, ["home", "work", "other"]
 50  * @param aAttribute  {string} The attribute, if any, in which the value of the
 51  *                             element is stored.  If not present, then it is
 52  *                             assumed that the value is stored as the child
 53  *                             node.
 54  * @constructor
 55  * @class
 56  */
 57 com.gContactSync.GElement = function gCS_GElement(aType, aTagName, aNamespace, aValidTypes, aAttribute) {
 58   this.contactType = aType;
 59   this.tagName     = aTagName;
 60   this.namespace = aNamespace;
 61   switch (aType) {
 62   case com.gContactSync.gdata.contacts.types.TYPED_WITH_ATTR:
 63     this.attribute = aAttribute;
 64   // fall through
 65   case com.gContactSync.gdata.contacts.types.TYPED_WITH_CHILD:
 66     this.types = aValidTypes;
 67     break;
 68   }  
 69 };
 70