]>
git.saurik.com Git - android/aapt.git/blob - Main.cpp
   2 // Copyright 2006 The Android Open Source Project 
   4 // Android Asset Packaging Tool main entry point. 
  10 #include <utils/threads.h> 
  11 #include <utils/List.h> 
  12 #include <utils/Errors.h> 
  18 using namespace android
; 
  20 static const char* gProgName 
= "aapt"; 
  23  * When running under Cygwin on Windows, this will convert slash-based 
  24  * paths into back-slash-based ones. Otherwise the ApptAssets file comparisons 
  25  * fail later as they use back-slash separators under Windows. 
  27  * This operates in-place on the path string. 
  29 void convertPath(char *path
) { 
  30   if (path 
!= NULL 
&& OS_PATH_SEPARATOR 
!= '/') { 
  31     for (; *path
; path
++) { 
  33         *path 
= OS_PATH_SEPARATOR
; 
  44     fprintf(stderr
, "Android Asset Packaging Tool\n\n"); 
  45     fprintf(stderr
, "Usage:\n"); 
  47         " %s l[ist] [-v] [-a] file.{zip,jar,apk}\n" 
  48         "   List contents of Zip-compatible archive.\n\n", gProgName
); 
  50         " %s d[ump] [--values] WHAT file.{apk} [asset [asset ...]]\n" 
  51         "   badging          Print the label and icon for the app declared in APK.\n" 
  52         "   permissions      Print the permissions from the APK.\n" 
  53         "   resources        Print the resource table from the APK.\n" 
  54         "   configurations   Print the configurations in the APK.\n" 
  55         "   xmltree          Print the compiled xmls in the given assets.\n" 
  56         "   xmlstrings       Print the strings of the given compiled xml assets.\n\n", gProgName
); 
  58         " %s p[ackage] [-d][-f][-m][-u][-v][-x][-z][-M AndroidManifest.xml] \\\n" 
  59         "        [-0 extension [-0 extension ...]] [-g tolerance] [-j jarfile] \\\n" 
  60         "        [--debug-mode] [--min-sdk-version VAL] [--target-sdk-version VAL] \\\n" 
  61         "        [--app-version VAL] [--app-version-name TEXT] [--custom-package VAL] \\\n" 
  62         "        [--rename-manifest-package PACKAGE] \\\n" 
  63         "        [--rename-instrumentation-target-package PACKAGE] \\\n" 
  64         "        [--utf16] [--auto-add-overlay] \\\n" 
  65         "        [--max-res-version VAL] \\\n" 
  66         "        [-I base-package [-I base-package ...]] \\\n" 
  67         "        [-A asset-source-dir]  [-G class-list-file] [-P public-definitions-file] \\\n" 
  68         "        [-S resource-sources [-S resource-sources ...]] " 
  69         "        [-F apk-file] [-J R-file-dir] \\\n" 
  70         "        [--product product1,product2,...] \\\n" 
  72         "        [raw-files-dir [raw-files-dir] ...]\n" 
  74         "   Package the android resources.  It will read assets and resources that are\n" 
  75         "   supplied with the -M -A -S or raw-files-dir arguments.  The -J -P -F and -R\n" 
  76         "   options control which files are output.\n\n" 
  79         " %s r[emove] [-v] file.{zip,jar,apk} file1 [file2 ...]\n" 
  80         "   Delete specified files from Zip-compatible archive.\n\n", 
  83         " %s a[dd] [-v] file.{zip,jar,apk} file1 [file2 ...]\n" 
  84         "   Add specified files to Zip-compatible archive.\n\n", gProgName
); 
  86         " %s c[runch] [-v] -S resource-sources ... -C output-folder ...\n" 
  87         "   Do PNG preprocessing and store the results in output folder.\n\n", gProgName
); 
  90         "   Print program version.\n\n", gProgName
); 
  93         "   -a  print Android-specific data (resources, manifest) when listing\n" 
  94         "   -c  specify which configurations to include.  The default is all\n" 
  95         "       configurations.  The value of the parameter should be a comma\n" 
  96         "       separated list of configuration values.  Locales should be specified\n" 
  97         "       as either a language or language-region pair.  Some examples:\n" 
 101         "       If you put the special locale, zz_ZZ on the list, it will perform\n" 
 102         "       pseudolocalization on the default locale, modifying all of the\n" 
 103         "       strings so you can look for strings that missed the\n" 
 104         "       internationalization process.  For example:\n" 
 106         "   -d  one or more device assets to include, separated by commas\n" 
 107         "   -f  force overwrite of existing files\n" 
 108         "   -g  specify a pixel tolerance to force images to grayscale, default 0\n" 
 109         "   -j  specify a jar or zip file containing classes to include\n" 
 110         "   -k  junk path of file(s) added\n" 
 111         "   -m  make package directories under location specified by -J\n" 
 112         "   -o  create overlay package (ie only resources; expects <overlay-package> in manifest)\n" 
 114         "   -p  pseudolocalize the default configuration\n" 
 116         "   -u  update existing packages (add new, replace older, remove deleted files)\n" 
 117         "   -v  verbose output\n" 
 118         "   -x  create extending (non-application) resource IDs\n" 
 119         "   -z  require localization of resource attributes marked with\n" 
 120         "       localization=\"suggested\"\n" 
 121         "   -A  additional directory in which to find raw asset files\n" 
 122         "   -G  A file to output proguard options into.\n" 
 123         "   -F  specify the apk file to output\n" 
 124         "   -I  add an existing package to base include set\n" 
 125         "   -J  specify where to output R.java resource constant definitions\n" 
 126         "   -M  specify full path to AndroidManifest.xml to include in zip\n" 
 127         "   -P  specify where to output public resource definitions\n" 
 128         "   -S  directory in which to find resources.  Multiple directories will be scanned\n" 
 129         "       and the first match found (left to right) will take precedence.\n" 
 130         "   -0  specifies an additional extension for which such files will not\n" 
 131         "       be stored compressed in the .apk.  An empty string means to not\n" 
 132         "       compress any files at all.\n" 
 134         "       inserts android:debuggable=\"true\" in to the application node of the\n" 
 135         "       manifest, making the application debuggable even on production devices.\n" 
 136         "   --min-sdk-version\n" 
 137         "       inserts android:minSdkVersion in to manifest.  If the version is 7 or\n" 
 138         "       higher, the default encoding for resources will be in UTF-8.\n" 
 139         "   --target-sdk-version\n" 
 140         "       inserts android:targetSdkVersion in to manifest.\n" 
 141         "   --max-res-version\n" 
 142         "       ignores versioned resource directories above the given value.\n" 
 144         "       when used with \"dump resources\" also includes resource values.\n" 
 146         "       inserts android:versionCode in to manifest.\n" 
 148         "       inserts android:versionName in to manifest.\n" 
 149         "   --custom-package\n" 
 150         "       generates R.java into a different package.\n" 
 151         "   --extra-packages\n" 
 152         "       generate R.java for libraries. Separate libraries with ':'.\n" 
 153         "   --generate-dependencies\n" 
 154         "       generate dependency files in the same directories for R.java and resource package\n" 
 155         "   --auto-add-overlay\n" 
 156         "       Automatically add resources that are only in overlays.\n" 
 157         "   --rename-manifest-package\n" 
 158         "       Rewrite the manifest so that its package name is the package name\n" 
 159         "       given here.  Relative class names (for example .Foo) will be\n" 
 160         "       changed to absolute names with the old package so that the code\n" 
 161         "       does not need to change.\n" 
 162         "   --rename-instrumentation-target-package\n" 
 163         "       Rewrite the manifest so that all of its instrumentation\n" 
 164         "       components target the given package.  Useful when used in\n" 
 165         "       conjunction with --rename-manifest-package to fix tests against\n" 
 166         "       a package that has been renamed.\n" 
 168         "       Specifies which variant to choose for strings that have\n" 
 169         "       product variants\n" 
 171         "       changes default encoding for resources to UTF-16.  Only useful when API\n" 
 172         "       level is set to 7 or higher where the default encoding is UTF-8.\n" 
 173         "   --non-constant-id\n" 
 174         "       Make the resources ID non constant. This is required to make an R java class\n" 
 175         "       that does not contain the final value but is used to make reusable compiled\n" 
 176         "       libraries that need to access resources.\n"); 
 180  * Dispatch the command. 
 182 int handleCommand(Bundle
* bundle
) 
 184     //printf("--- command %d (verbose=%d force=%d):\n", 
 185     //    bundle->getCommand(), bundle->getVerbose(), bundle->getForce()); 
 186     //for (int i = 0; i < bundle->getFileSpecCount(); i++) 
 187     //    printf("  %d: '%s'\n", i, bundle->getFileSpecEntry(i)); 
 189     switch (bundle
->getCommand()) { 
 190     case kCommandVersion
:   return doVersion(bundle
); 
 191     case kCommandList
:      return doList(bundle
); 
 192     case kCommandDump
:      return doDump(bundle
); 
 193     case kCommandAdd
:       return doAdd(bundle
); 
 194     case kCommandRemove
:    return doRemove(bundle
); 
 195     case kCommandPackage
:   return doPackage(bundle
); 
 196     case kCommandCrunch
:    return doCrunch(bundle
); 
 198         fprintf(stderr
, "%s: requested command not yet supported\n", gProgName
); 
 206 int main(int argc
, char* const argv
[]) 
 208     char *prog 
= argv
[0]; 
 210     bool wantUsage 
= false; 
 211     int result 
= 1;    // pessimistically assume an error. 
 214     /* default to compression */ 
 215     bundle
.setCompressionMethod(ZipEntry::kCompressDeflated
); 
 222     if (argv
[1][0] == 'v') 
 223         bundle
.setCommand(kCommandVersion
); 
 224     else if (argv
[1][0] == 'd') 
 225         bundle
.setCommand(kCommandDump
); 
 226     else if (argv
[1][0] == 'l') 
 227         bundle
.setCommand(kCommandList
); 
 228     else if (argv
[1][0] == 'a') 
 229         bundle
.setCommand(kCommandAdd
); 
 230     else if (argv
[1][0] == 'r') 
 231         bundle
.setCommand(kCommandRemove
); 
 232     else if (argv
[1][0] == 'p') 
 233         bundle
.setCommand(kCommandPackage
); 
 234     else if (argv
[1][0] == 'c') 
 235         bundle
.setCommand(kCommandCrunch
); 
 237         fprintf(stderr
, "ERROR: Unknown command '%s'\n", argv
[1]); 
 245      * Pull out flags.  We support "-fv" and "-f -v". 
 247     while (argc 
&& argv
[0][0] == '-') { 
 249         const char* cp 
= argv
[0] +1; 
 251         while (*cp 
!= '\0') { 
 254                 bundle
.setVerbose(true); 
 257                 bundle
.setAndroidList(true); 
 263                     fprintf(stderr
, "ERROR: No argument supplied for '-c' option\n"); 
 267                 bundle
.addConfigurations(argv
[0]); 
 270                 bundle
.setForce(true); 
 276                     fprintf(stderr
, "ERROR: No argument supplied for '-g' option\n"); 
 280                 tolerance 
= atoi(argv
[0]); 
 281                 bundle
.setGrayscaleTolerance(tolerance
); 
 282                 printf("%s: Images with deviation <= %d will be forced to grayscale.\n", prog
, tolerance
); 
 285                 bundle
.setJunkPath(true); 
 288                 bundle
.setMakePackageDirs(true); 
 291                 bundle
.setIsOverlayPackage(true); 
 295                 bundle
.setPseudolocalize(true); 
 299                 bundle
.setUpdate(true); 
 302                 bundle
.setExtending(true); 
 305                 bundle
.setRequireLocalization(true); 
 311                     fprintf(stderr
, "ERROR: No argument supplied for '-j' option\n"); 
 315                 convertPath(argv
[0]); 
 316                 bundle
.addJarFile(argv
[0]); 
 322                     fprintf(stderr
, "ERROR: No argument supplied for '-A' option\n"); 
 326                 convertPath(argv
[0]); 
 327                 bundle
.setAssetSourceDir(argv
[0]); 
 333                     fprintf(stderr
, "ERROR: No argument supplied for '-G' option\n"); 
 337                 convertPath(argv
[0]); 
 338                 bundle
.setProguardFile(argv
[0]); 
 344                     fprintf(stderr
, "ERROR: No argument supplied for '-I' option\n"); 
 348                 convertPath(argv
[0]); 
 349                 bundle
.addPackageInclude(argv
[0]); 
 355                     fprintf(stderr
, "ERROR: No argument supplied for '-F' option\n"); 
 359                 convertPath(argv
[0]); 
 360                 bundle
.setOutputAPKFile(argv
[0]); 
 366                     fprintf(stderr
, "ERROR: No argument supplied for '-J' option\n"); 
 370                 convertPath(argv
[0]); 
 371                 bundle
.setRClassDir(argv
[0]); 
 377                     fprintf(stderr
, "ERROR: No argument supplied for '-M' option\n"); 
 381                 convertPath(argv
[0]); 
 382                 bundle
.setAndroidManifestFile(argv
[0]); 
 388                     fprintf(stderr
, "ERROR: No argument supplied for '-P' option\n"); 
 392                 convertPath(argv
[0]); 
 393                 bundle
.setPublicOutputFile(argv
[0]); 
 399                     fprintf(stderr
, "ERROR: No argument supplied for '-S' option\n"); 
 403                 convertPath(argv
[0]); 
 404                 bundle
.addResourceSourceDir(argv
[0]); 
 410                     fprintf(stderr
, "ERROR: No argument supplied for '-C' option\n"); 
 414                 convertPath(argv
[0]); 
 415                 bundle
.setCrunchedOutputDir(argv
[0]); 
 421                     fprintf(stderr
, "ERROR: No argument supplied for '-e' option\n"); 
 425                 if (argv
[0][0] != 0) { 
 426                     bundle
.addNoCompressExtension(argv
[0]); 
 428                     bundle
.setCompressionMethod(ZipEntry::kCompressStored
); 
 432                 if (strcmp(cp
, "-debug-mode") == 0) { 
 433                     bundle
.setDebugMode(true); 
 434                 } else if (strcmp(cp
, "-min-sdk-version") == 0) { 
 438                         fprintf(stderr
, "ERROR: No argument supplied for '--min-sdk-version' option\n"); 
 442                     bundle
.setMinSdkVersion(argv
[0]); 
 443                 } else if (strcmp(cp
, "-target-sdk-version") == 0) { 
 447                         fprintf(stderr
, "ERROR: No argument supplied for '--target-sdk-version' option\n"); 
 451                     bundle
.setTargetSdkVersion(argv
[0]); 
 452                 } else if (strcmp(cp
, "-max-sdk-version") == 0) { 
 456                         fprintf(stderr
, "ERROR: No argument supplied for '--max-sdk-version' option\n"); 
 460                     bundle
.setMaxSdkVersion(argv
[0]); 
 461                 } else if (strcmp(cp
, "-max-res-version") == 0) { 
 465                         fprintf(stderr
, "ERROR: No argument supplied for '--max-res-version' option\n"); 
 469                     bundle
.setMaxResVersion(argv
[0]); 
 470                 } else if (strcmp(cp
, "-version-code") == 0) { 
 474                         fprintf(stderr
, "ERROR: No argument supplied for '--version-code' option\n"); 
 478                     bundle
.setVersionCode(argv
[0]); 
 479                 } else if (strcmp(cp
, "-version-name") == 0) { 
 483                         fprintf(stderr
, "ERROR: No argument supplied for '--version-name' option\n"); 
 487                     bundle
.setVersionName(argv
[0]); 
 488                 } else if (strcmp(cp
, "-values") == 0) { 
 489                     bundle
.setValues(true); 
 490                 } else if (strcmp(cp
, "-custom-package") == 0) { 
 494                         fprintf(stderr
, "ERROR: No argument supplied for '--custom-package' option\n"); 
 498                     bundle
.setCustomPackage(argv
[0]); 
 499                 } else if (strcmp(cp
, "-extra-packages") == 0) { 
 503                         fprintf(stderr
, "ERROR: No argument supplied for '--extra-packages' option\n"); 
 507                     bundle
.setExtraPackages(argv
[0]); 
 508                 } else if (strcmp(cp
, "-generate-dependencies") == 0) { 
 509                     bundle
.setGenDependencies(true); 
 510                 } else if (strcmp(cp
, "-utf16") == 0) { 
 511                     bundle
.setWantUTF16(true); 
 512                 } else if (strcmp(cp
, "-rename-manifest-package") == 0) { 
 516                         fprintf(stderr
, "ERROR: No argument supplied for '--rename-manifest-package' option\n"); 
 520                     bundle
.setManifestPackageNameOverride(argv
[0]); 
 521                 } else if (strcmp(cp
, "-rename-instrumentation-target-package") == 0) { 
 525                         fprintf(stderr
, "ERROR: No argument supplied for '--rename-instrumentation-target-package' option\n"); 
 529                     bundle
.setInstrumentationPackageNameOverride(argv
[0]); 
 530                 } else if (strcmp(cp
, "-auto-add-overlay") == 0) { 
 531                     bundle
.setAutoAddOverlay(true); 
 532                 } else if (strcmp(cp
, "-product") == 0) { 
 536                         fprintf(stderr
, "ERROR: No argument supplied for '--product' option\n"); 
 540                     bundle
.setProduct(argv
[0]); 
 541                 } else if (strcmp(cp
, "-non-constant-id") == 0) { 
 542                     bundle
.setNonConstantId(true); 
 543                 } else if (strcmp(cp
, "-no-crunch") == 0) { 
 544                     bundle
.setUseCrunchCache(true); 
 546                     fprintf(stderr
, "ERROR: Unknown option '-%s'\n", cp
); 
 550                 cp 
+= strlen(cp
) - 1; 
 553                 fprintf(stderr
, "ERROR: Unknown flag '-%c'\n", *cp
); 
 565      * We're past the flags.  The rest all goes straight in. 
 567     bundle
.setFileSpec(argv
, argc
); 
 569     result 
= handleCommand(&bundle
); 
 577     //printf("--> returning %d\n", result);