1*4bfccde5SXin Li<?xml version="1.0" encoding="UTF-8"?> 2*4bfccde5SXin Li<!-- 3*4bfccde5SXin Li * Copyright (C) 2011 The Android Open Source Project 4*4bfccde5SXin Li * 5*4bfccde5SXin Li * Licensed under the Apache License, Version 2.0 (the "License"); 6*4bfccde5SXin Li * you may not use this file except in compliance with the License. 7*4bfccde5SXin Li * You may obtain a copy of the License at 8*4bfccde5SXin Li * 9*4bfccde5SXin Li * http://www.apache.org/licenses/LICENSE-2.0 10*4bfccde5SXin Li * 11*4bfccde5SXin Li * Unless required by applicable law or agreed to in writing, software 12*4bfccde5SXin Li * distributed under the License is distributed on an "AS IS" BASIS, 13*4bfccde5SXin Li * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 14*4bfccde5SXin Li * See the License for the specific language governing permissions and 15*4bfccde5SXin Li * limitations under the License. 16*4bfccde5SXin Li--> 17*4bfccde5SXin Li<xsd:schema 18*4bfccde5SXin Li targetNamespace="http://schemas.android.com/sdk/android/addon/2" 19*4bfccde5SXin Li xmlns:xsd="http://www.w3.org/2001/XMLSchema" 20*4bfccde5SXin Li xmlns:sdk="http://schemas.android.com/sdk/android/addon/2" 21*4bfccde5SXin Li elementFormDefault="qualified" 22*4bfccde5SXin Li attributeFormDefault="unqualified" 23*4bfccde5SXin Li version="1"> 24*4bfccde5SXin Li 25*4bfccde5SXin Li <!-- The repository contains a collection of downloadable items known as 26*4bfccde5SXin Li "packages". Each package has a type and various attributes and contains 27*4bfccde5SXin Li a list of file "archives" that can be downloaded for specific OSes. 28*4bfccde5SXin Li 29*4bfccde5SXin Li An Android Addon repository is a web site that contains an "addon.xml" 30*4bfccde5SXin Li file that conforms to this XML Schema. 31*4bfccde5SXin Li 32*4bfccde5SXin Li History: 33*4bfccde5SXin Li - v1 is used by the SDK Updater in Tools r8. It is split out of the 34*4bfccde5SXin Li main SDK Repository XML Schema and can only contain <addon> and 35*4bfccde5SXin Li <extra> packages. 36*4bfccde5SXin Li 37*4bfccde5SXin Li - v2 is used by the SDK Updater in Tools r12. 38*4bfccde5SXin Li - <extra> element now has a <project-files> element that contains 1 or 39*4bfccde5SXin Li or more <path>, each indicating the relative path of a file that this package 40*4bfccde5SXin Li can contribute to installed projects. 41*4bfccde5SXin Li - <addon> element now has an optional <layoutlib> that indicates the API 42*4bfccde5SXin Li and revision of the layout library for this particular add-on, if any. 43*4bfccde5SXin Li --> 44*4bfccde5SXin Li 45*4bfccde5SXin Li <xsd:element name="sdk-addon" type="sdk:repositoryType" /> 46*4bfccde5SXin Li 47*4bfccde5SXin Li <xsd:complexType name="repositoryType"> 48*4bfccde5SXin Li <xsd:annotation> 49*4bfccde5SXin Li <xsd:documentation> 50*4bfccde5SXin Li The repository contains a collection of downloadable packages. 51*4bfccde5SXin Li </xsd:documentation> 52*4bfccde5SXin Li </xsd:annotation> 53*4bfccde5SXin Li <xsd:choice minOccurs="0" maxOccurs="unbounded"> 54*4bfccde5SXin Li <xsd:element name="add-on" type="sdk:addonType" /> 55*4bfccde5SXin Li <xsd:element name="extra" type="sdk:extraType" /> 56*4bfccde5SXin Li <xsd:element name="license" type="sdk:licenseType" /> 57*4bfccde5SXin Li </xsd:choice> 58*4bfccde5SXin Li </xsd:complexType> 59*4bfccde5SXin Li 60*4bfccde5SXin Li <!-- The definition of an SDK Add-on package. --> 61*4bfccde5SXin Li 62*4bfccde5SXin Li <xsd:complexType name="addonType"> 63*4bfccde5SXin Li <xsd:annotation> 64*4bfccde5SXin Li <xsd:documentation>An SDK add-on package.</xsd:documentation> 65*4bfccde5SXin Li </xsd:annotation> 66*4bfccde5SXin Li <xsd:all> 67*4bfccde5SXin Li <!-- The name of the add-on. --> 68*4bfccde5SXin Li <xsd:element name="name" type="xsd:normalizedString" /> 69*4bfccde5SXin Li <!-- The vendor of the add-on. --> 70*4bfccde5SXin Li <xsd:element name="vendor" type="xsd:normalizedString" /> 71*4bfccde5SXin Li <!-- The Android API Level for the add-on. An int > 0. --> 72*4bfccde5SXin Li <xsd:element name="api-level" type="xsd:positiveInteger" /> 73*4bfccde5SXin Li <!-- Note: Add-ons do not support 'codenames' (a.k.a. API previews). --> 74*4bfccde5SXin Li <!-- The revision, an int > 0, incremented each time a new 75*4bfccde5SXin Li package is generated. --> 76*4bfccde5SXin Li <xsd:element name="revision" type="xsd:positiveInteger" /> 77*4bfccde5SXin Li 78*4bfccde5SXin Li <!-- An add-on can declare 0 or more libraries. 79*4bfccde5SXin Li This element is mandatory but it can be empty. 80*4bfccde5SXin Li --> 81*4bfccde5SXin Li 82*4bfccde5SXin Li <xsd:element name="libs"> 83*4bfccde5SXin Li <xsd:complexType> 84*4bfccde5SXin Li <xsd:sequence minOccurs="0" maxOccurs="unbounded"> 85*4bfccde5SXin Li <xsd:element name="lib"> 86*4bfccde5SXin Li <xsd:complexType> 87*4bfccde5SXin Li <xsd:all> 88*4bfccde5SXin Li <!-- The name of the library. --> 89*4bfccde5SXin Li <xsd:element name="name" type="xsd:normalizedString" /> 90*4bfccde5SXin Li <!-- The optional description of this add-on library. --> 91*4bfccde5SXin Li <xsd:element name="description" type="xsd:string" minOccurs="0" /> 92*4bfccde5SXin Li </xsd:all> 93*4bfccde5SXin Li </xsd:complexType> 94*4bfccde5SXin Li </xsd:element> 95*4bfccde5SXin Li </xsd:sequence> 96*4bfccde5SXin Li </xsd:complexType> 97*4bfccde5SXin Li </xsd:element> 98*4bfccde5SXin Li 99*4bfccde5SXin Li <!-- optional elements --> 100*4bfccde5SXin Li 101*4bfccde5SXin Li <!-- The optional license of this package. If present, users will have 102*4bfccde5SXin Li to agree to it before downloading. --> 103*4bfccde5SXin Li <xsd:element name="uses-license" type="sdk:usesLicenseType" minOccurs="0" /> 104*4bfccde5SXin Li <!-- The optional description of this package. --> 105*4bfccde5SXin Li <xsd:element name="description" type="xsd:string" minOccurs="0" /> 106*4bfccde5SXin Li <!-- The optional description URL of this package --> 107*4bfccde5SXin Li <xsd:element name="desc-url" type="xsd:token" minOccurs="0" /> 108*4bfccde5SXin Li <!-- The optional release note for this package. --> 109*4bfccde5SXin Li <xsd:element name="release-note" type="xsd:string" minOccurs="0" /> 110*4bfccde5SXin Li <!-- The optional release note URL of this package --> 111*4bfccde5SXin Li <xsd:element name="release-url" type="xsd:token" minOccurs="0" /> 112*4bfccde5SXin Li <!-- A list of file archives for this package. --> 113*4bfccde5SXin Li <xsd:element name="archives" type="sdk:archivesType" /> 114*4bfccde5SXin Li 115*4bfccde5SXin Li <!-- An optional element indicating the package is obsolete. 116*4bfccde5SXin Li The string content is however currently not defined and ignored. --> 117*4bfccde5SXin Li <xsd:element name="obsolete" type="xsd:string" minOccurs="0" /> 118*4bfccde5SXin Li 119*4bfccde5SXin Li <!-- Optional information on the layoutlib packaged in this platform. --> 120*4bfccde5SXin Li <xsd:element name="layoutlib" type="sdk:layoutlibType" minOccurs="0" /> 121*4bfccde5SXin Li </xsd:all> 122*4bfccde5SXin Li </xsd:complexType> 123*4bfccde5SXin Li 124*4bfccde5SXin Li 125*4bfccde5SXin Li <!-- The definition of a layout library used by an addon. --> 126*4bfccde5SXin Li 127*4bfccde5SXin Li <xsd:complexType name="layoutlibType" > 128*4bfccde5SXin Li <xsd:annotation> 129*4bfccde5SXin Li <xsd:documentation> 130*4bfccde5SXin Li Version information for a layoutlib included in an addon. 131*4bfccde5SXin Li .</xsd:documentation> 132*4bfccde5SXin Li </xsd:annotation> 133*4bfccde5SXin Li <xsd:all> 134*4bfccde5SXin Li <!-- The layoutlib API level, an int > 0, 135*4bfccde5SXin Li incremented with each new incompatible lib. --> 136*4bfccde5SXin Li <xsd:element name="api" type="xsd:positiveInteger" /> 137*4bfccde5SXin Li <!-- The incremental minor revision for that API, e.g. in case of bug fixes. 138*4bfccde5SXin Li Optional. An int >= 0, assumed to be 0 if the element is missing. --> 139*4bfccde5SXin Li <xsd:element name="revision" type="xsd:nonNegativeInteger" minOccurs="0" /> 140*4bfccde5SXin Li </xsd:all> 141*4bfccde5SXin Li </xsd:complexType> 142*4bfccde5SXin Li 143*4bfccde5SXin Li 144*4bfccde5SXin Li <!-- The definition of an SDK extra package. This kind of package is for 145*4bfccde5SXin Li "free" content. Such packages are installed in SDK/vendor/path. 146*4bfccde5SXin Li 147*4bfccde5SXin Li Important implementation detail: this element is duplicated in the 148*4bfccde5SXin Li sdk-repository-N.xsd schema and must be kept in sync there. This is 149*4bfccde5SXin Li simpler than trying to use some kind of of include or to request 150*4bfccde5SXin Li that clients use a third XML schema for common parts. 151*4bfccde5SXin Li --> 152*4bfccde5SXin Li 153*4bfccde5SXin Li <xsd:complexType name="extraType" > 154*4bfccde5SXin Li <xsd:annotation> 155*4bfccde5SXin Li <xsd:documentation> 156*4bfccde5SXin Li An SDK extra package. This kind of package is for "free" content. 157*4bfccde5SXin Li Such packages are installed in SDK/vendor/path. 158*4bfccde5SXin Li </xsd:documentation> 159*4bfccde5SXin Li </xsd:annotation> 160*4bfccde5SXin Li <xsd:all> 161*4bfccde5SXin Li 162*4bfccde5SXin Li <!-- The install path top folder name. It must not be empty. 163*4bfccde5SXin Li The segments "add-ons", "docs", "platforms", "platform-tools", "temp" 164*4bfccde5SXin Li and "tools" are reserved and cannot be used. 165*4bfccde5SXin Li --> 166*4bfccde5SXin Li <xsd:element name="vendor" type="sdk:segmentType" /> 167*4bfccde5SXin Li 168*4bfccde5SXin Li <!-- The install path sub-folder name. It must not be empty. --> 169*4bfccde5SXin Li <xsd:element name="path" type="sdk:segmentType" /> 170*4bfccde5SXin Li 171*4bfccde5SXin Li <!-- The revision, an int > 0, incremented each time a new 172*4bfccde5SXin Li package is generated. --> 173*4bfccde5SXin Li <xsd:element name="revision" type="xsd:positiveInteger" /> 174*4bfccde5SXin Li 175*4bfccde5SXin Li <!-- A list of file archives for this package. --> 176*4bfccde5SXin Li <xsd:element name="archives" type="sdk:archivesType" /> 177*4bfccde5SXin Li 178*4bfccde5SXin Li <!-- optional elements --> 179*4bfccde5SXin Li 180*4bfccde5SXin Li <!-- The optional license of this package. If present, users will have 181*4bfccde5SXin Li to agree to it before downloading. --> 182*4bfccde5SXin Li <xsd:element name="uses-license" type="sdk:usesLicenseType" minOccurs="0" /> 183*4bfccde5SXin Li <!-- The optional description of this package. --> 184*4bfccde5SXin Li <xsd:element name="description" type="xsd:string" minOccurs="0" /> 185*4bfccde5SXin Li <!-- The optional description URL of this package --> 186*4bfccde5SXin Li <xsd:element name="desc-url" type="xsd:token" minOccurs="0" /> 187*4bfccde5SXin Li <!-- The optional release note for this package. --> 188*4bfccde5SXin Li <xsd:element name="release-note" type="xsd:string" minOccurs="0" /> 189*4bfccde5SXin Li <!-- The optional release note URL of this package --> 190*4bfccde5SXin Li <xsd:element name="release-url" type="xsd:token" minOccurs="0" /> 191*4bfccde5SXin Li <!-- The minimal revision of tools required by this package. 192*4bfccde5SXin Li Optional. If present, must be an int > 0. --> 193*4bfccde5SXin Li <xsd:element name="min-tools-rev" type="xsd:positiveInteger" minOccurs="0" /> 194*4bfccde5SXin Li <!-- The minimal API level required by this package. 195*4bfccde5SXin Li Optional. If present, must be an int > 0. --> 196*4bfccde5SXin Li <xsd:element name="min-api-level" type="xsd:positiveInteger" minOccurs="0" /> 197*4bfccde5SXin Li <!-- An optional element indicating the package is obsolete. 198*4bfccde5SXin Li The string content is however currently not defined and ignored. --> 199*4bfccde5SXin Li <xsd:element name="obsolete" type="xsd:string" minOccurs="0" /> 200*4bfccde5SXin Li 201*4bfccde5SXin Li <!-- A list of project files contributed by this package. Optional. --> 202*4bfccde5SXin Li <xsd:element name="project-files" type="sdk:projectFilesType" minOccurs="0" /> 203*4bfccde5SXin Li </xsd:all> 204*4bfccde5SXin Li </xsd:complexType> 205*4bfccde5SXin Li 206*4bfccde5SXin Li 207*4bfccde5SXin Li <!-- The definition of a path segment used by the extra element. --> 208*4bfccde5SXin Li 209*4bfccde5SXin Li <xsd:simpleType name="segmentType"> 210*4bfccde5SXin Li <xsd:annotation> 211*4bfccde5SXin Li <xsd:documentation> 212*4bfccde5SXin Li One path segment for the install path of an extra element. 213*4bfccde5SXin Li It must be a single-segment path. It must not be empty. 214*4bfccde5SXin Li </xsd:documentation> 215*4bfccde5SXin Li </xsd:annotation> 216*4bfccde5SXin Li <xsd:restriction base="xsd:token"> 217*4bfccde5SXin Li <xsd:pattern value="[a-zA-Z0-9_]+"/> 218*4bfccde5SXin Li </xsd:restriction> 219*4bfccde5SXin Li </xsd:simpleType> 220*4bfccde5SXin Li 221*4bfccde5SXin Li 222*4bfccde5SXin Li <!-- The definition of a license to be referenced by the uses-license element. --> 223*4bfccde5SXin Li 224*4bfccde5SXin Li <xsd:complexType name="licenseType"> 225*4bfccde5SXin Li <xsd:annotation> 226*4bfccde5SXin Li <xsd:documentation> 227*4bfccde5SXin Li A license definition. Such a license must be used later as a reference 228*4bfccde5SXin Li using a uses-license element in one of the package elements. 229*4bfccde5SXin Li </xsd:documentation> 230*4bfccde5SXin Li </xsd:annotation> 231*4bfccde5SXin Li <xsd:simpleContent> 232*4bfccde5SXin Li <xsd:extension base="xsd:string"> 233*4bfccde5SXin Li <xsd:attribute name="id" type="xsd:ID" /> 234*4bfccde5SXin Li <xsd:attribute name="type" type="xsd:token" fixed="text" /> 235*4bfccde5SXin Li </xsd:extension> 236*4bfccde5SXin Li </xsd:simpleContent> 237*4bfccde5SXin Li </xsd:complexType> 238*4bfccde5SXin Li 239*4bfccde5SXin Li 240*4bfccde5SXin Li <!-- Type describing the license used by a package. 241*4bfccde5SXin Li The license MUST be defined using a license node and referenced 242*4bfccde5SXin Li using the ref attribute of the license element inside a package. 243*4bfccde5SXin Li --> 244*4bfccde5SXin Li 245*4bfccde5SXin Li <xsd:complexType name="usesLicenseType"> 246*4bfccde5SXin Li <xsd:annotation> 247*4bfccde5SXin Li <xsd:documentation> 248*4bfccde5SXin Li Describes the license used by a package. The license MUST be defined 249*4bfccde5SXin Li using a license node and referenced using the ref attribute of the 250*4bfccde5SXin Li license element inside a package. 251*4bfccde5SXin Li </xsd:documentation> 252*4bfccde5SXin Li </xsd:annotation> 253*4bfccde5SXin Li <xsd:attribute name="ref" type="xsd:IDREF" /> 254*4bfccde5SXin Li </xsd:complexType> 255*4bfccde5SXin Li 256*4bfccde5SXin Li 257*4bfccde5SXin Li <!-- A collection of files that can be downloaded for a given architecture. 258*4bfccde5SXin Li The <archives> node is mandatory in the repository elements and the 259*4bfccde5SXin Li collection must have at least one <archive> declared. 260*4bfccde5SXin Li Each archive is a zip file that will be unzipped in a location that depends 261*4bfccde5SXin Li on its package type. 262*4bfccde5SXin Li --> 263*4bfccde5SXin Li 264*4bfccde5SXin Li <xsd:complexType name="archivesType"> 265*4bfccde5SXin Li <xsd:annotation> 266*4bfccde5SXin Li <xsd:documentation> 267*4bfccde5SXin Li A collection of files that can be downloaded for a given architecture. 268*4bfccde5SXin Li The <archives> node is mandatory in the repository packages and the 269*4bfccde5SXin Li collection must have at least one <archive> declared. 270*4bfccde5SXin Li Each archive is a zip file that will be unzipped in a location that depends 271*4bfccde5SXin Li on its package type. 272*4bfccde5SXin Li </xsd:documentation> 273*4bfccde5SXin Li </xsd:annotation> 274*4bfccde5SXin Li <xsd:sequence minOccurs="1" maxOccurs="unbounded"> 275*4bfccde5SXin Li <!-- One archive file --> 276*4bfccde5SXin Li <xsd:element name="archive"> 277*4bfccde5SXin Li <xsd:complexType> 278*4bfccde5SXin Li <!-- Properties of the archive file --> 279*4bfccde5SXin Li <xsd:all> 280*4bfccde5SXin Li <!-- The size in bytes of the archive to download. --> 281*4bfccde5SXin Li <xsd:element name="size" type="xsd:positiveInteger" /> 282*4bfccde5SXin Li <!-- The checksum of the archive file. --> 283*4bfccde5SXin Li <xsd:element name="checksum" type="sdk:checksumType" /> 284*4bfccde5SXin Li <!-- The URL is an absolute URL if it starts with http://, https:// 285*4bfccde5SXin Li or ftp://. Otherwise it is relative to the parent directory that 286*4bfccde5SXin Li contains this repository.xml --> 287*4bfccde5SXin Li <xsd:element name="url" type="xsd:token" /> 288*4bfccde5SXin Li </xsd:all> 289*4bfccde5SXin Li 290*4bfccde5SXin Li <!-- Attributes that identify the OS and architecture --> 291*4bfccde5SXin Li <xsd:attribute name="os" use="required"> 292*4bfccde5SXin Li <xsd:simpleType> 293*4bfccde5SXin Li <xsd:restriction base="xsd:token"> 294*4bfccde5SXin Li <xsd:enumeration value="any" /> 295*4bfccde5SXin Li <xsd:enumeration value="linux" /> 296*4bfccde5SXin Li <xsd:enumeration value="macosx" /> 297*4bfccde5SXin Li <xsd:enumeration value="windows" /> 298*4bfccde5SXin Li </xsd:restriction> 299*4bfccde5SXin Li </xsd:simpleType> 300*4bfccde5SXin Li </xsd:attribute> 301*4bfccde5SXin Li <xsd:attribute name="arch" use="optional"> 302*4bfccde5SXin Li <xsd:simpleType> 303*4bfccde5SXin Li <xsd:restriction base="xsd:token"> 304*4bfccde5SXin Li <xsd:enumeration value="any" /> 305*4bfccde5SXin Li <xsd:enumeration value="ppc" /> 306*4bfccde5SXin Li <xsd:enumeration value="x86" /> 307*4bfccde5SXin Li <xsd:enumeration value="x86_64" /> 308*4bfccde5SXin Li </xsd:restriction> 309*4bfccde5SXin Li </xsd:simpleType> 310*4bfccde5SXin Li </xsd:attribute> 311*4bfccde5SXin Li </xsd:complexType> 312*4bfccde5SXin Li </xsd:element> 313*4bfccde5SXin Li </xsd:sequence> 314*4bfccde5SXin Li </xsd:complexType> 315*4bfccde5SXin Li 316*4bfccde5SXin Li 317*4bfccde5SXin Li <!-- A collection of file paths available in an <extra> package 318*4bfccde5SXin Li that can be installed in an Android project. 319*4bfccde5SXin Li If present, the <project-files> collection must contain at least one path. 320*4bfccde5SXin Li Each path is relative to the root directory of the package. 321*4bfccde5SXin Li --> 322*4bfccde5SXin Li 323*4bfccde5SXin Li <xsd:complexType name="projectFilesType"> 324*4bfccde5SXin Li <xsd:annotation> 325*4bfccde5SXin Li <xsd:documentation> 326*4bfccde5SXin Li A collection of file paths available in an <extra> package 327*4bfccde5SXin Li that can be installed in an Android project. 328*4bfccde5SXin Li If present, the <project-files> collection must contain at least one path. 329*4bfccde5SXin Li Each path is relative to the root directory of the package. 330*4bfccde5SXin Li </xsd:documentation> 331*4bfccde5SXin Li </xsd:annotation> 332*4bfccde5SXin Li <xsd:sequence minOccurs="1" maxOccurs="unbounded"> 333*4bfccde5SXin Li <!-- One JAR Path, relative to the root folder of the package. --> 334*4bfccde5SXin Li <xsd:element name="path" type="xsd:string" /> 335*4bfccde5SXin Li </xsd:sequence> 336*4bfccde5SXin Li </xsd:complexType> 337*4bfccde5SXin Li 338*4bfccde5SXin Li 339*4bfccde5SXin Li <!-- The definition of a file checksum --> 340*4bfccde5SXin Li 341*4bfccde5SXin Li <xsd:simpleType name="sha1Number"> 342*4bfccde5SXin Li <xsd:annotation> 343*4bfccde5SXin Li <xsd:documentation>A SHA1 checksum.</xsd:documentation> 344*4bfccde5SXin Li </xsd:annotation> 345*4bfccde5SXin Li <xsd:restriction base="xsd:string"> 346*4bfccde5SXin Li <xsd:pattern value="([0-9a-fA-F]){40}"/> 347*4bfccde5SXin Li </xsd:restriction> 348*4bfccde5SXin Li </xsd:simpleType> 349*4bfccde5SXin Li 350*4bfccde5SXin Li <xsd:complexType name="checksumType"> 351*4bfccde5SXin Li <xsd:annotation> 352*4bfccde5SXin Li <xsd:documentation>A file checksum, currently only SHA1.</xsd:documentation> 353*4bfccde5SXin Li </xsd:annotation> 354*4bfccde5SXin Li <xsd:simpleContent> 355*4bfccde5SXin Li <xsd:extension base="sdk:sha1Number"> 356*4bfccde5SXin Li <xsd:attribute name="type" type="xsd:token" fixed="sha1" /> 357*4bfccde5SXin Li </xsd:extension> 358*4bfccde5SXin Li </xsd:simpleContent> 359*4bfccde5SXin Li </xsd:complexType> 360*4bfccde5SXin Li 361*4bfccde5SXin Li</xsd:schema> 362