build.gradle 이란 빌드 배포 도구이다.
안드로이드 스튜디오는 코드의 편집만을 할 수 있는 IDE(Integrated Development Environment, 통합 개발 환경)이라서 별도의 빌드 배포 도구가 필요로 한다. Gradle이 안드로이드 스튜디오가 선택한 빌드 배포 도구이다.
Gradle은 앱 리소스 및 소스 코드를 컴파일하고 개발자가 테스트, 구축, 서명 및 배포할 수 있는 APK 또는 Android App Bundle 로 패키징하고, 개발자가 유연한 맞춤 빌드 구성을 정의하도록 허용한다.
.gradle 파일은 JVM 동적 언어인 Groovy DSL(Domain Specific Language)을 사용해야한다.
Groovy DSL 이 사용에 불편함이 있어 Kotlin DSL 사용을 권장하기 시작했다. 이는 새글로 작성할 예정이다.
project와 module 두 가지 형태의 build.gradle 이 있다.
프로젝트의 모든 모듈에 공통으로 적용되는 빌드의 구성을 정의한다.
모듈에서 사용할 플러그인의 환경을 정의한다.
// Top-level build file where you can add configuration options common to all sub-projects/modules.
buildscript {
// 모든 모듈에 적용할 것 작성
}
plugins {
id 'com.android.application' version '7.2.1' apply false
id 'com.android.library' version '7.2.1' apply false
id 'org.jetbrains.kotlin.android' version '1.6.10' apply false
}
task clean(type: Delete) {
delete rootProject.buildDir
}
각 모듈마다 독립된 build.gradle 파일이 존재한다.
plugins {
id 'com.android.application'
id 'org.jetbrains.kotlin.android'
}
android {
compileSdk 32
defaultConfig {
applicationId "com.twaun95.myapplication"
minSdk 26
targetSdk 32
versionCode 1
versionName "1.0"
testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
}
}
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_8
targetCompatibility JavaVersion.VERSION_1_8
}
kotlinOptions {
jvmTarget = '1.8'
}
}
dependencies {
implementation 'androidx.core:core-ktx:1.7.0'
implementation 'androidx.appcompat:appcompat:1.4.2'
implementation 'com.google.android.material:material:1.6.1'
implementation 'androidx.constraintlayout:constraintlayout:2.1.4'
testImplementation 'junit:junit:4.13.2'
androidTestImplementation 'androidx.test.ext:junit:1.1.3'
androidTestImplementation 'androidx.test.espresso:espresso-core:3.4.0'
}
plugins{} : 안드로이드 전용 빌드 옵션
android{} : 모든 안드로이드 관련 설정
compileSdk : Android API 레벨. (해달 레벨 이하 이용 가능)
minSdk : 최소 API 레벨.
targetSdk : 테스트에 사용하는 API 레벨
buildTypes{} : 빌드 타입 종류 지정 (release, develoption, staging.. 등등)
dependencies{} : 특정 버전을 선택해서 라이브러리 추가
+) dependencies{} 에 라이브러리가 계속 쌓이다 보면 코드가 길어져 관리가 힘들어진다.
이에 라이브러리를 별도로 종류별로, 버전별로 쉽게 관리할 수 있는 방법들이 있다.
- 별도의 ext를 사용한 groovy DSL 파일(블로그 내 링크 예정)
- Kotlin DSL(블로그 내 링크 예정)