הגדרת ה-build

מערכת ה-build של Android מהדרת את משאבי האפליקציה ואת קוד המקור, ואורזת אותם בחבילות APK או Android App Bundle שאפשר לבדוק, לפרוס, לחתום ולהפיץ.

במאמרים סקירה כללית של Gradle build ומבנה של Android build, הסברנו על מושגי build ועל המבנה של אפליקציית Android. עכשיו הגיע הזמן להגדיר את ה-build.

מילון מונחים של Android build

‫Gradle והפלאגין Android Gradle עוזרים לכם להגדיר את ההיבטים הבאים של ה-build:

סוגי בנייה

סוגי ה-Build מגדירים מאפיינים מסוימים ש-Gradle משתמש בהם כשמבצעים Build לאפליקציה ואורזים אותה. בדרך כלל מגדירים סוגי Build לשלבים שונים במחזור החיים של הפיתוח.

לדוגמה, סוג ה-build של ניפוי הבאגים מאפשר אפשרויות ניפוי באגים וחותם על האפליקציה באמצעות מפתח ניפוי הבאגים, בעוד שסוג ה-build של הגרסה יכול לכווץ, להסתיר ולחתום על האפליקציה באמצעות מפתח הגרסה לצורך הפצה.

כדי לבצע build של האפליקציה, צריך להגדיר לפחות סוג build אחד. Android Studio יוצר כברירת מחדל את סוגי ה-build של debug ו-release. כדי להתחיל להתאים אישית את הגדרות האריזה של האפליקציה, כדאי לקרוא על הגדרת סוגי build.

טעמים של מוצרים
טעמי מוצר מייצגים גרסאות שונות של האפליקציה שאפשר להשיק למשתמשים, כמו גרסאות חינמיות וגרסאות בתשלום. אתם יכולים להתאים אישית את טעמי המוצר כדי להשתמש בקוד ובמשאבים שונים, תוך שיתוף ושימוש חוזר בחלקים שמשותפים לכל הגרסאות של האפליקציה. טעמי מוצר הם אופציונליים, ואתם צריכים ליצור אותם באופן ידני. כדי להתחיל ליצור גרסאות שונות של האפליקציה, כדאי לקרוא איך מגדירים טעמים של מוצרים.
יצירת וריאציות
וריאציית build היא שילוב של סוג build וטעם מוצר, והיא ההגדרה ש-Gradle משתמש בה כדי לבצע build לאפליקציה. באמצעות וריאציות build, אפשר לבצע build לגרסת ניפוי הבאגים של טעמי המוצר במהלך הפיתוח, ולגרסאות חתומות של טעמי המוצר לצורך הפצה. למרות שאתם לא מגדירים וריאציות של גרסאות build באופן ישיר, אתם מגדירים את סוגי ה-build ואת טעמי המוצר שמרכיבים אותן. יצירה של סוגי build נוספים או של טעמי מוצר נוספים יוצרת גם וריאציות build נוספות. במאמר הגדרת וריאציות של גרסאות Build יש הסבר על יצירה וניהול של וריאציות של גרסאות Build.
רשומות במניפסט
אפשר לציין ערכים לחלק מהמאפיינים של קובץ המניפסט בהגדרת וריאציית הבנייה. ערכי הבנייה האלה מבטלים את הערכים הקיימים בקובץ המניפסט. האפשרות הזו שימושית אם רוצים ליצור כמה וריאציות של האפליקציה עם שם אפליקציה שונה, גרסת SDK מינימלית שונה או גרסת SDK לטירגוט שונה. אם יש כמה קובצי מניפסט, כלי המיזוג של קובצי המניפסט ממזג את הגדרות המניפסט.
תלות
מערכת ה-build מנהלת את יחסי התלות של הפרויקט ממערכת הקבצים המקומית וממאגרים מרוחקים. זה אומר שלא צריך לחפש, להוריד ולהעתיק באופן ידני חבילות בינאריות של התלויות לספריית הפרויקט. מידע נוסף זמין במאמר בנושא הוספת תלות ב-build.
חתימה
מערכת ה-build מאפשרת לציין הגדרות חתימה בהגדרות ה-build, והיא יכולה לחתום על האפליקציה באופן אוטומטי במהלך תהליך ה-build. מערכת ה-build חותמת על גרסת הניפוי באגים באמצעות מפתח ואישור ברירת מחדל, תוך שימוש בפרטי כניסה ידועים כדי למנוע הצגת בקשה להזנת סיסמה בזמן ה-build. מערכת ה-build לא חותמת על גרסת ההפצה, אלא אם מגדירים במפורש הגדרת חתימה ל-build הזה. אם אין לכם מפתח להפצה, אתם יכולים ליצור אותו כמו שמתואר במאמר חתימה על האפליקציה. חובה ליצור גרסאות הפצה חתומות כדי להפיץ אפליקציות דרך רוב חנויות האפליקציות.
כיווץ קוד ומשאבים
מערכת ה-build מאפשרת לציין קובץ כללי ProGuard שונה לכל וריאציה של build. כשמבצעים Build לאפליקציה, מערכת ה-Build מחילה את קבוצת הכללים המתאימה כדי לצמצם את הקוד והמשאבים באמצעות כלי הצמצום המובנים שלה, כמו R8. כדי להקטין את הגודל של קובץ ה-APK או ה-AAB, אפשר לצמצם את הקוד והמשאבים.
תמיכה בחבילות APK מרובות
מערכת ה-build מאפשרת ליצור באופן אוטומטי קובצי APK שונים, שכל אחד מהם מכיל רק את הקוד והמשאבים שנדרשים לצפיפות מסך ספציפית או לממשק בינארי של אפליקציה (ABI). מידע נוסף זמין במאמר יצירת כמה חבילות APK. עם זאת, מומלץ להעלות קובץ AAB יחיד, כי הוא מאפשר פיצול לפי שפה בנוסף לצפיפות פיקסלים ו-ABI, וגם חוסך את הצורך להעלות כמה פריטי מידע שנוצרו בתהליך פיתוח ל-Google Play. כל האפליקציות החדשות שנשלחות אחרי אוגוסט 2021 חייבות להשתמש ב-AAB.

גרסאות Java ב-builds של Android

לא משנה אם קוד המקור שלכם כתוב ב-Java, ב-Kotlin או בשתיהן, יש כמה מקומות שבהם אתם צריכים לבחור גרסה של JDK או של שפת Java בשביל הבנייה. פרטים נוספים זמינים במאמר גרסאות Java בגרסאות build של Android.

קובצי תצורת build

כדי ליצור הגדרות build מותאמות אישית, צריך לבצע שינויים בקובץ הגדרות build אחד או יותר. בקובצי הטקסט הפשוטים האלה נעשה שימוש בשפה ספציפית לדומיין (DSL) כדי לתאר ולשנות את הלוגיקה של ה-build באמצעות סקריפט Kotlin, שהוא ניב של שפת Kotlin. אפשר גם להשתמש ב-Groovy, שהיא שפה דינמית למכונה וירטואלית של Java‏ (JVM), כדי להגדיר את הגרסאות.

לא צריך לדעת Kotlin script או Groovy כדי להתחיל להגדיר את תהליך הבנייה, כי הפלאגין Android Gradle כולל את רוב רכיבי ה-DSL שצריך. מידע נוסף על Android Gradle plugin DSL זמין במאמרי העזרה בנושא DSL. תסריט Kotlin מסתמך גם על Gradle Kotlin DSL הבסיסי.

כשמתחילים פרויקט חדש, Android Studio יוצר באופן אוטומטי חלק מהקבצים האלה ומאכלס אותם על סמך הגדרות ברירת מחדל הגיוניות. במאמר מבנה של Android build יש סקירה כללית של הקבצים שנוצרו.

קובץ Gradle Wrapper

ה-Gradle wrapper ‏ (gradlew) הוא אפליקציה קטנה שכלולה בקוד המקור ומורידה ומפעילה את Gradle עצמו. כך מתקבלת הרצה עקבית יותר של הבנייה. המפתחים מורידים את מקור האפליקציה ומריצים את gradlew. הפעולה הזו מורידה את הפצת Gradle הנדרשת ומפעילה את Gradle כדי לבנות את האפליקציה.

הקובץ gradle/wrapper/gradle-wrapper.properties מכיל מאפיין, distributionUrl, שמתאר איזו גרסה של Gradle משמשת להרצת הבנייה.

distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-8.0-bin.zip
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists

קובץ ההגדרות של Gradle

הקובץ settings.gradle.kts (עבור Kotlin DSL) או הקובץ settings.gradle (עבור Groovy DSL) נמצא בספריית הפרויקט הבסיסית. קובץ ההגדרות הזה מגדיר את הגדרות המאגר ברמת הפרויקט, ומציין ל-Gradle אילו מודולים לכלול כשמבצעים build של האפליקציה. בפרויקטים עם כמה מודולים צריך לציין כל מודול שרוצים לכלול ב-build הסופי.

ברוב הפרויקטים, הקובץ נראה כך כברירת מחדל:

Kotlin

pluginManagement {

    /**
      * The pluginManagement.repositories block configures the
      * repositories Gradle uses to search or download the Gradle plugins and
      * their transitive dependencies. Gradle pre-configures support for remote
      * repositories such as JCenter, Maven Central, and Ivy. You can also use
      * local repositories or define your own remote repositories. Here we
      * define the Gradle Plugin Portal, Google's Maven repository,
      * and the Maven Central Repository as the repositories Gradle should use to look for its
      * dependencies.
      */

    repositories {
        gradlePluginPortal()
        google()
        mavenCentral()
    }
}
dependencyResolutionManagement {

    /**
      * The dependencyResolutionManagement.repositories
      * block is where you configure the repositories and dependencies used by
      * all modules in your project, such as libraries that you are using to
      * create your application. However, you should configure module-specific
      * dependencies in each module-level build.gradle file. For new projects,
      * Android Studio includes Google's Maven repository and the Maven Central
      * Repository by default, but it does not configure any dependencies (unless
      * you select a template that requires some).
      */

  repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
  repositories {
      google()
      mavenCentral()
  }
}
rootProject.name = "My Application"
include(":app")

מגניב

pluginManagement {

    /**
      * The pluginManagement.repositories block configures the
      * repositories Gradle uses to search or download the Gradle plugins and
      * their transitive dependencies. Gradle pre-configures support for remote
      * repositories such as JCenter, Maven Central, and Ivy. You can also use
      * local repositories or define your own remote repositories. Here we
      * define the Gradle Plugin Portal, Google's Maven repository,
      * and the Maven Central Repository as the repositories Gradle should use to look for its
      * dependencies.
      */

    repositories {
        gradlePluginPortal()
        google()
        mavenCentral()
    }
}
dependencyResolutionManagement {

    /**
      * The dependencyResolutionManagement.repositories
      * block is where you configure the repositories and dependencies used by
      * all modules in your project, such as libraries that you are using to
      * create your application. However, you should configure module-specific
      * dependencies in each module-level build.gradle file. For new projects,
      * Android Studio includes Google's Maven repository and the Maven Central
      * Repository by default, but it does not configure any dependencies (unless
      * you select a template that requires some).
      */

    repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
    repositories {
        google()
        mavenCentral()
    }
}
rootProject.name = "My Application"
include ':app'

קובץ ה-build ברמה העליונה

הקובץ build.gradle.kts (ב-Kotlin DSL) או הקובץ build.gradle (ב-Groovy DSL) ברמה העליונה נמצא בספריית הפרויקט הבסיסית. בדרך כלל מוגדרות בו הגרסאות הנפוצות של התוספים שבהם נעשה שימוש במודולים בפרויקט.

קוד לדוגמה שמתאר את הגדרות ברירת המחדל ואת רכיבי ה-DSL בסקריפט הבנייה ברמה העליונה אחרי יצירת פרויקט חדש:

Kotlin

plugins {

    /**
     * Use `apply false` in the top-level build.gradle file to add a Gradle
     * plugin as a build dependency but not apply it to the current (root)
     * project. Don't use `apply false` in sub-projects. For more information,
     * see Applying external plugins with same version to subprojects.
     */

    id("com.android.application") version "8.11.0" apply false
    id("com.android.library") version "8.11.0" apply false
    id("org.jetbrains.kotlin.android") version "2.1.20" apply false
}

מגניב

plugins {

    /**
     * Use `apply false` in the top-level build.gradle file to add a Gradle
     * plugin as a build dependency but not apply it to the current (root)
     * project. Don't use `apply false` in sub-projects. For more information,
     * see Applying external plugins with same version to subprojects.
     */

    id 'com.android.application' version '8.11.0' apply false
    id 'com.android.library' version '8.11.0' apply false
    id 'org.jetbrains.kotlin.android' version '2.1.20' apply false
}