Gradle - สร้างสคริปต์
Gradle สร้างไฟล์สคริปต์สำหรับจัดการสองสิ่ง หนึ่งคือprojects และอีกอย่างหนึ่งคือ tasks. ทุกงานสร้าง Gradle แสดงถึงโครงการอย่างน้อยหนึ่งโครงการ โปรเจ็กต์แสดงถึง JAR ไลบรารีหรือเว็บแอ็พพลิเคชันหรืออาจแสดงถึง ZIP ที่ประกอบจาก JAR ที่สร้างโดยโปรเจ็กต์อื่น กล่าวง่ายๆคือโครงการประกอบด้วยงานที่แตกต่างกัน งานหมายถึงชิ้นงานที่บิวด์ดำเนินการ งานอาจกำลังรวบรวมบางคลาสสร้าง JAR สร้าง Javadoc หรือเผยแพร่ไฟล์เก็บถาวรไปยังที่เก็บ
Gradle ใช้ Groovy language สำหรับการเขียนสคริปต์
การเขียน Build Script
Gradle จัดเตรียมภาษาเฉพาะโดเมน (DSL) สำหรับอธิบายบิลด์ สิ่งนี้ใช้ภาษา Groovy เพื่อให้ง่ายต่อการอธิบายงานสร้าง บิวด์สคริปต์ของ Gradle แต่ละตัวเข้ารหัสโดยใช้ UTF-8 บันทึกแบบออฟไลน์และตั้งชื่อเป็น build.gradle
build.gradle
เรากำลังอธิบายเกี่ยวกับงานและโครงการโดยใช้สคริปต์ Groovy คุณสามารถรันบิวด์ Gradle โดยใช้คำสั่ง Gradle คำสั่งนี้ค้นหาไฟล์ที่เรียกว่าbuild.gradle. ดูตัวอย่างต่อไปนี้ซึ่งแสดงถึงสคริปต์ขนาดเล็กที่พิมพ์tutorialspoint. คัดลอกและบันทึกสคริปต์ต่อไปนี้ลงในไฟล์ชื่อbuild.gradle. สร้างสคริปต์นี้กำหนดชื่องาน hello ซึ่งใช้ในการพิมพ์สตริงบทช่วยสอน
task hello {
doLast {
println 'tutorialspoint'
}
}
ดำเนินการคำสั่งต่อไปนี้ในพรอมต์คำสั่ง เรียกใช้สคริปต์ข้างต้น คุณควรดำเนินการนี้โดยที่ไฟล์ build.gradle ถูกเก็บไว้
C:\> gradle –q hello
เอาท์พุต:
tutorialspoint
หากคุณคิดว่างานทำงานคล้ายกับเป้าหมายของ ANT แสดงว่าถูกต้อง - งาน Gradle เทียบเท่ากับเป้าหมาย ANT
คุณสามารถลดความซับซ้อนของงาน hello นี้ได้โดยระบุช็อตคัท (แสดงถึงสัญลักษณ์ <<) ไปยังไฟล์ doLastคำให้การ. หากคุณเพิ่มทางลัดนี้ในงานด้านบนhello จะมีลักษณะเหมือนสคริปต์ต่อไปนี้
task hello << {
println 'tutorialspoint'
}
เช่นเดียวกับด้านบนคุณสามารถเรียกใช้สคริปต์ด้านบนโดยใช้ไฟล์ gradle –q hello คำสั่ง
สคริปต์เกรดส่วนใหญ่ใช้ออบเจ็กต์จริงสองรายการหนึ่งคืออ็อบเจ็กต์โครงการและอีกอันคืออ็อบเจ็กต์สคริปต์
Project Object- แต่ละสคริปต์อธิบายเกี่ยวกับโครงการหนึ่งหรือหลายโครงการ ขณะดำเนินการสคริปต์นี้จะกำหนดค่า Project Object คุณสามารถเรียกใช้วิธีการบางอย่างและใช้คุณสมบัติในสคริปต์การสร้างของคุณซึ่งได้รับมอบหมายให้กับวัตถุโครงการ
Script Object- Gradle นำโค้ดสคริปต์ไปยังคลาสที่ใช้ Script Interface แล้วรัน ซึ่งหมายความว่าคุณสมบัติและวิธีการทั้งหมดที่ประกาศโดยอินเทอร์เฟซสคริปต์มีอยู่ในสคริปต์ของคุณ
ตารางต่อไปนี้กำหนดรายการ standard project properties. คุณสมบัติทั้งหมดเหล่านี้มีอยู่ในบิลด์สคริปต์ของคุณ
เลขที่ | ชื่อ | ประเภท | ค่าเริ่มต้น |
---|---|---|---|
1 | โครงการ | โครงการ | อินสแตนซ์โครงการ |
2 | ชื่อ | สตริง | ชื่อของไดเร็กทอรีโปรเจ็กต์ |
3 | เส้นทาง | สตริง | เส้นทางที่แน่นอนของโครงการ |
4 | คำอธิบาย | สตริง | คำอธิบายสำหรับโครงการ |
5 | projectDir | ไฟล์ | ไดเร็กทอรีที่มีบิลด์สคริปต์ |
6 | buildDir | ไฟล์ | projectDir / build |
7 | กลุ่ม | วัตถุ | ไม่ระบุ |
8 | รุ่น | วัตถุ | ไม่ระบุ |
9 | มด | AntBuilder | อินสแตนซ์ AntBuilder |
พื้นฐาน Groovy
สคริปต์การสร้าง Gradle ใช้ Groovy API แบบเต็มความยาว เมื่อเริ่มต้นโปรดดูตัวอย่างต่อไปนี้
ตัวอย่างต่อไปนี้อธิบายเกี่ยวกับการแปลงสตริงเป็นตัวพิมพ์ใหญ่
คัดลอกและบันทึกรหัสที่ระบุด้านล่างลงใน build.gradle ไฟล์.
task upper << {
String expString = 'TUTORIALS point'
println "Original: " + expString
println "Upper case: " + expString.toUpperCase()
}
ดำเนินการคำสั่งต่อไปนี้ในพรอมต์คำสั่ง มันรันสคริปต์ที่กำหนดข้างต้น คุณควรดำเนินการนี้โดยที่ไฟล์ build.gradle ถูกเก็บไว้
C:\> gradle –q upper
เอาท์พุต:
Original: TUTORIALS point
Upper case: TUTORIALS POINT
ตัวอย่างต่อไปนี้อธิบายเกี่ยวกับการพิมพ์ค่าของพารามิเตอร์นัย ($ it) เป็นเวลา 4 ครั้ง
คัดลอกและบันทึกรหัสต่อไปนี้ลงใน build.gradle ไฟล์.
task count << {
4.times {
print "$it "
}
}
ดำเนินการคำสั่งต่อไปนี้ในพรอมต์คำสั่ง มันรันสคริปต์ที่กำหนดข้างต้น คุณควรดำเนินการนี้โดยที่ไฟล์ build.gradle ถูกเก็บไว้
$ gradle –q count
เอาท์พุต:
0 1 2 3
ภาษา Groovy มีคุณสมบัติมากมายในคุณสมบัติที่สำคัญเหล่านี้จะกล่าวถึงด้านล่าง
วิธี Groovy JDK
Groovy เพิ่มวิธีการที่มีประโยชน์มากมายให้กับคลาส Java มาตรฐาน ตัวอย่างเช่น Iterable API จาก JDK ใช้ไฟล์each() วิธีการที่วนซ้ำองค์ประกอบของอินเทอร์เฟซที่ทำซ้ำได้
คัดลอกและบันทึกรหัสต่อไปนี้ลงใน build.gradle ไฟล์.
task groovyJDK << {
String myName = "Marc";
myName.each() {
println "${it}"
};
}
ดำเนินการคำสั่งต่อไปนี้ในพรอมต์คำสั่ง มันรันสคริปต์ที่กำหนดข้างต้น คุณควรดำเนินการนี้โดยที่ไฟล์ build.gradle เก็บไว้
C:\> gradle –q groovyJDK
เอาท์พุต:
M
a
r
c
ผู้เข้าถึงทรัพย์สิน
คุณสามารถเข้าถึงเมธอด getter และ setter ที่เหมาะสมของคุณสมบัติเฉพาะได้โดยอัตโนมัติโดยระบุการอ้างอิง
ตัวอย่างต่อไปนี้กำหนดไวยากรณ์ของ getter และ setter วิธีการของคุณสมบัติ buildDir.
// Using a getter method
println project.buildDir
println getProject().getBuildDir()
// Using a setter method
project.buildDir = 'target'
getProject().setBuildDir('target')
วงเล็บเสริมในการเรียกเมธอด
Groovy มีคุณลักษณะพิเศษในการเรียกเมธอดซึ่งเป็นวงเล็บเป็นทางเลือกสำหรับการเรียกเมธอด คุณลักษณะนี้ใช้กับการเขียนสคริปต์ Gradle เช่นกัน
ดูไวยากรณ์ต่อไปนี้ ที่กำหนดวิธีการโทรsystemProperty ของ test วัตถุ.
test.systemProperty 'some.prop', 'value'
test.systemProperty('some.prop', 'value')
การปิดเป็นพารามิเตอร์สุดท้ายของวิธีการ
Gradle DSL ใช้การปิดในหลาย ๆ ที่ โดยที่พารามิเตอร์สุดท้ายของเมธอดคือการปิดคุณสามารถปิดได้หลังจากการเรียกเมธอด
ข้อมูลโค้ดต่อไปนี้กำหนดไวยากรณ์ที่ Closures ใช้เป็นที่เก็บ () พารามิเตอร์วิธีการ
repositories {
println "in a closure"
}
repositories() {
println "in a closure"
}
repositories({ println "in a closure" })
การนำเข้าเริ่มต้น
Gradle จะเพิ่มชุดคำสั่งนำเข้าให้กับสคริปต์ Gradle โดยอัตโนมัติ รายการต่อไปนี้แสดงแพ็กเกจการนำเข้าเริ่มต้นไปยังสคริปต์ Gradle
import org.gradle.*
import org.gradle.api.*
import org.gradle.api.artifacts.*
import org.gradle.api.artifacts.cache.*
import org.gradle.api.artifacts.component.*
import org.gradle.api.artifacts.dsl.*
import org.gradle.api.artifacts.ivy.*
import org.gradle.api.artifacts.maven.*
import org.gradle.api.artifacts.query.*
import org.gradle.api.artifacts.repositories.*
import org.gradle.api.artifacts.result.*
import org.gradle.api.component.*
import org.gradle.api.credentials.*
import org.gradle.api.distribution.*
import org.gradle.api.distribution.plugins.*
import org.gradle.api.dsl.*
import org.gradle.api.execution.*
import org.gradle.api.file.*
import org.gradle.api.initialization.*
import org.gradle.api.initialization.dsl.*
import org.gradle.api.invocation.*
import org.gradle.api.java.archives.*
import org.gradle.api.logging.*
import org.gradle.api.plugins.*
import org.gradle.api.plugins.announce.*
import org.gradle.api.plugins.antlr.*
import org.gradle.api.plugins.buildcomparison.gradle.*
import org.gradle.api.plugins.jetty.*
import org.gradle.api.plugins.osgi.*
import org.gradle.api.plugins.quality.*
import org.gradle.api.plugins.scala.*
import org.gradle.api.plugins.sonar.*
import org.gradle.api.plugins.sonar.model.*
import org.gradle.api.publish.*
import org.gradle.api.publish.ivy.*
import org.gradle.api.publish.ivy.plugins.*
import org.gradle.api.publish.ivy.tasks.*
import org.gradle.api.publish.maven.*
import org.gradle.api.publish.maven.plugins.*
import org.gradle.api.publish.maven.tasks.*
import org.gradle.api.publish.plugins.*
import org.gradle.api.reporting.*
import org.gradle.api.reporting.components.*
import org.gradle.api.reporting.dependencies.*
import org.gradle.api.reporting.model.*
import org.gradle.api.reporting.plugins.*
import org.gradle.api.resources.*
import org.gradle.api.specs.*
import org.gradle.api.tasks.*
import org.gradle.api.tasks.ant.*
import org.gradle.api.tasks.application.*
import org.gradle.api.tasks.bundling.*
import org.gradle.api.tasks.compile.*
import org.gradle.api.tasks.diagnostics.*
import org.gradle.api.tasks.incremental.*
import org.gradle.api.tasks.javadoc.*
import org.gradle.api.tasks.scala.*
import org.gradle.api.tasks.testing.*
import org.gradle.api.tasks.testing.junit.*
import org.gradle.api.tasks.testing.testng.*
import org.gradle.api.tasks.util.*
import org.gradle.api.tasks.wrapper.*
import org.gradle.authentication.*
import org.gradle.authentication.http.*
import org.gradle.buildinit.plugins.*
import org.gradle.buildinit.tasks.*
import org.gradle.external.javadoc.*
import org.gradle.ide.cdt.*
import org.gradle.ide.cdt.tasks.*
import org.gradle.ide.visualstudio.*
import org.gradle.ide.visualstudio.plugins.*
import org.gradle.ide.visualstudio.tasks.*
import org.gradle.ivy.*
import org.gradle.jvm.*
import org.gradle.jvm.application.scripts.*
import org.gradle.jvm.application.tasks.*
import org.gradle.jvm.platform.*
import org.gradle.jvm.plugins.*
import org.gradle.jvm.tasks.*
import org.gradle.jvm.tasks.api.*
import org.gradle.jvm.test.*
import org.gradle.jvm.toolchain.*
import org.gradle.language.assembler.*
import org.gradle.language.assembler.plugins.*
import org.gradle.language.assembler.tasks.*
import org.gradle.language.base.*
import org.gradle.language.base.artifact.*
import org.gradle.language.base.plugins.*
import org.gradle.language.base.sources.*
import org.gradle.language.c.*
import org.gradle.language.c.plugins.*
import org.gradle.language.c.tasks.*
import org.gradle.language.coffeescript.*
import org.gradle.language.cpp.*
import org.gradle.language.cpp.plugins.*
import org.gradle.language.cpp.tasks.*
import org.gradle.language.java.*
import org.gradle.language.java.artifact.*
import org.gradle.language.java.plugins.*
import org.gradle.language.java.tasks.*
import org.gradle.language.javascript.*
import org.gradle.language.jvm.*
import org.gradle.language.jvm.plugins.*
import org.gradle.language.jvm.tasks.*
import org.gradle.language.nativeplatform.*
import org.gradle.language.nativeplatform.tasks.*
import org.gradle.language.objectivec.*
import org.gradle.language.objectivec.plugins.*
import org.gradle.language.objectivec.tasks.*
import org.gradle.language.objectivecpp.*
import org.gradle.language.objectivecpp.plugins.*
import org.gradle.language.objectivecpp.tasks.*
import org.gradle.language.rc.*
import org.gradle.language.rc.plugins.*
import org.gradle.language.rc.tasks.*
import org.gradle.language.routes.*
import org.gradle.language.scala.*
import org.gradle.language.scala.plugins.*
import org.gradle.language.scala.tasks.*
import org.gradle.language.scala.toolchain.*
import org.gradle.language.twirl.*
import org.gradle.maven.*
import org.gradle.model.*
import org.gradle.nativeplatform.*
import org.gradle.nativeplatform.platform.*
import org.gradle.nativeplatform.plugins.*
import org.gradle.nativeplatform.tasks.*
import org.gradle.nativeplatform.test.*
import org.gradle.nativeplatform.test.cunit.*
import org.gradle.nativeplatform.test.cunit.plugins.*
import org.gradle.nativeplatform.test.cunit.tasks.*
import org.gradle.nativeplatform.test.googletest.*
import org.gradle.nativeplatform.test.googletest.plugins.*
import org.gradle.nativeplatform.test.plugins.*
import org.gradle.nativeplatform.test.tasks.*
import org.gradle.nativeplatform.toolchain.*
import org.gradle.nativeplatform.toolchain.plugins.*
import org.gradle.platform.base.*
import org.gradle.platform.base.binary
import org.gradle.platform.base.component.*
import org.gradle.platform.base.plugins.*
import org.gradle.platform.base.test.*
import org.gradle.play.*
import org.gradle.play.distribution.*
import org.gradle.play.platform.*
import org.gradle.play.plugins.*
import org.gradle.play.tasks.*
import org.gradle.play.toolchain.*
import org.gradle.plugin.use.*
import org.gradle.plugins.ear.*
import org.gradle.plugins.ear.descriptor.*
import org.gradle.plugins.ide.api.*
import org.gradle.plugins.ide.eclipse.*
import org.gradle.plugins.ide.idea.*
import org.gradle.plugins.javascript.base.*
import org.gradle.plugins.javascript.coffeescript.*
import org.gradle.plugins.javascript.envjs.*
import org.gradle.plugins.javascript.envjs.browser.*
import org.gradle.plugins.javascript.envjs.http.*
import org.gradle.plugins.javascript.envjs.http.simple.*
import org.gradle.plugins.javascript.jshint.*
import org.gradle.plugins.javascript.rhino.*
import org.gradle.plugins.javascript.rhino.worker.*
import org.gradle.plugins.signing.*
import org.gradle.plugins.signing.signatory.*
import org.gradle.plugins.signing.signatory.pgp.*
import org.gradle.plugins.signing.type.*
import org.gradle.plugins.signing.type.pgp.*
import org.gradle.process.*
import org.gradle.sonar.runner.*
import org.gradle.sonar.runner.plugins.*
import org.gradle.sonar.runner.tasks.*
import org.gradle.testing.jacoco.plugins.*
import org.gradle.testing.jacoco.tasks.*
import org.gradle.testkit.runner.*
import org.gradle.util.*