העברה ל-Kotlin 2.0
אם אתם משתמשים בגרסה 3.0 ואילך של Consumer SDK ל-Android, אתם צריכים לשדרג ל-Kotlin 2.0. בדף הזה מוסבר איך לעבור לגרסה החדשה של Kotlin.
תאימות של Gradle ו-AGP
ל-Kotlin 2.0 יש דרישות לגבי הגרסאות המינימליות והמקסימליות של Gradle ושל Android Gradle Plugin (AGP). חשוב לוודא שהפרויקט שלכם עומד בדרישות האלה ל-Kotlin 2.0.
הגרסה המינימלית של AGP ל-Consumer SDK 3.0 ואילך
כדי להשתמש ב-Consumer SDK 3.0, צריך להשתמש ב-AGP 7.3 ואילך.
מצב R8 מלא
גרסה 3 ומטה של SDK למשתמשים פרטיים לא תומכת במצב R8 מלא. אם האפליקציה שלכם מיועדת ל-AGP 8.0 ואילך, אתם צריכים להשבית באופן מפורש את מצב R8 המלא.
# settings.gradle
android.enableR8.fullMode=false
תאימות לגרסת Kotlin
Kotlin תומכת בתאימות לאחור עם שלוש גרסאות קודמות של השפה. המשמעות היא שאם אתם כבר משתמשים ב-Kotlin בגרסה 1.7 ואילך עם Consumer SDK, תוכלו לשדרג ל-Kotlin בגרסה 2.0 בלי שתצטרכו לפתור את כל השינויים שגורמים לבעיות תאימות. עם זאת, התאימות ל-Kotlin חלה רק על תכונות שפה יציבות. אם אתם משתמשים בתכונות אלפא, בטא או ניסיוניות בשפת Kotlin, יכול להיות שתצטרכו לבצע שינויים נוספים כשמשדרגים.
התרעות לגבי תאימות ל-Kotlin
כפי שצוין בקטע הקודם, כשמשדרגים את Kotlin, המערכת תומכת בעד 3 גרסאות קודמות של השפה. Kotlin מספקת שני דגלים שעוזרים להגביל שינויים שעלולים לשבור את התאימות:
גרסה בשפה X.Y
הדגל הזה מחזיר שינויים שגורמים לבעיות בהתנהגות של גרסה קודמת של Kotlin.
לדוגמה, אם אתם משתמשים ב-Kotlin 1.7, אתם יכולים לציין [ -
language-version 1.7]
והשינויים החדשים שגורמים לבעיות לא יחולו יותר:
android {
kotlinOptions {
languageVersion = '1.7'
}
}
api-version X.Y
הדגל הזה מונע שימוש בממשקי API חדשים לפני שהקוד התלוי במורד הזרם מוכן לשילוב של Kotlin 2.0.
android {
kotlinOptions {
apiVersion = '1.7'
}
}
גישה ממוקדת יותר
בנוסף לשימוש בדגלי תאימות של Kotlin, מומלץ לעיין בהערות הגרסה של Kotlin ולבחור את ההתנהגויות שרוצים לשמור מהגרסה שממנה משדרגים. במדריכי התאימות של Kotlin לכל גרסה מופיעה רשימה של שינויים שעלולים לשבור תאימות ודגלים שאפשר להגדיר כדי לשמור על ההתנהגות המקורית: