ArgsOption Parser
public class ArgsOptionParser
extends OptionSetter
java.lang.Object | ||
↳ | com.android.tradefed.config.OptionSetter | |
↳ | com.android.tradefed.config.ArgsOptionParser |
เติมฟิลด์ Option
จากอาร์กิวเมนต์บรรทัดคำสั่งที่แยกวิเคราะห์
Option
อย่างน้อยหนึ่งฟิลด์ ตัวเลือกแบบยาวจับคู่กับชื่อ Option
และตัวเลือกแบบสั้นจับคู่กับชื่อแบบสั้น Option
ชื่อตัวเลือกและชื่อย่อของตัวเลือกแต่ละรายการต้องไม่ซ้ำกันสำหรับฟิลด์ Option
อื่นๆ ทั้งหมดภายในวัตถุเดียวกัน อาร์กิวเมนต์ตัวเลือกเดียวสามารถแมปกับฟิลด์ Option
หลายรายการที่มีชื่อเดียวกันในหลายๆ วัตถุ อาร์กิวเมนต์ Option
สามารถระบุเนมสเปซเพื่ออ้างถึงฟิลด์ Option
ภายในออบเจกต์เดียวโดยไม่ซ้ำกันโดยใช้ชื่อคลาสเต็มของออบเจ็กต์นั้นหรือค่านามแฝงของ OptionClass
ที่คั่นด้วย ':' เช่น --classname:optionname optionvalue or --optionclassalias:optionname optionvalue.ตัวเลือกสั้นๆ ง่ายๆ คือ "-" ตามด้วยอักขระตัวเลือกสั้นๆ หากตัวเลือกต้องการอาร์กิวเมนต์ (ซึ่งเป็นจริงสำหรับตัวเลือกที่ไม่ใช่บูลีน) อาจเขียนเป็นพารามิเตอร์แยกต่างหาก แต่ไม่จำเป็นต้องเป็นเช่นนั้น นั่นคือยอมรับได้ทั้ง "-f out.txt" และ "-fout.txt" เป็นไปได้ที่จะระบุตัวเลือกสั้นหลายตัวหลังจาก "-" ตัวเดียว ตราบใดที่ทั้งหมด (ยกเว้นตัวเลือกสุดท้าย) ไม่ต้องการอาร์กิวเมนต์ ตัวเลือกแบบยาวเริ่มต้นด้วย "--" ตามด้วยอักขระหลายตัว หากตัวเลือกต้องการอาร์กิวเมนต์ อาจเขียนหลังชื่อตัวเลือกโดยตรง โดยคั่นด้วย "=" หรือเป็นอาร์กิวเมนต์ถัดไป (นั่นคือ "--file=out.txt" หรือ "--file out.txt") ตัวเลือกบูลีนแบบยาว '--name' จะได้รับการแสดงร่วม '--no-name' โดยอัตโนมัติ เมื่อพิจารณาตัวเลือก "--flag" ดังนั้น "--flag", "--no-flag", "--flag=true" และ "--flag=false" จึงใช้ได้ทั้งหมด แม้ว่าจะไม่มี "--flag" จริง" หรือ "--flag เท็จ" ได้รับอนุญาต (เนื่องจาก "--flag" เพียงอย่างเดียวก็เพียงพอแล้ว "จริง" หรือ "เท็จ" ต่อไปนี้จึงถูกตีความแยกกัน) คุณสามารถใช้ "ใช่" และ "ไม่" เป็นคำพ้องความหมายสำหรับ "จริง" และ "เท็จ" แต่ละสตริงที่ไม่ได้ขึ้นต้นด้วย "-" และไม่ใช่อาร์กิวเมนต์ที่จำเป็นสำหรับตัวเลือกก่อนหน้าคืออาร์กิวเมนต์ตำแหน่งที่ไม่ใช่ตัวเลือก เช่นเดียวกับสตริงที่ต่อเนื่องกันทั้งหมด แต่ละสตริงหลัง "--" เป็นอาร์กิวเมนต์ระบุตำแหน่งที่ไม่ใช่ตัวเลือก ฟิลด์ที่เกี่ยวข้องกับตัวเลือกจะได้รับการอัปเดตเมื่อตัวเลือกถูกประมวลผล อาร์กิวเมนต์ตำแหน่งที่เหลืออยู่จะถูกส่งกลับเป็นรายการ<String> นี่คือตัวอย่างง่ายๆ:
// Non-@Option fields will be ignored. class Options { @Option(name = "quiet", shortName = 'q') boolean quiet = false; // Here the user can use --no-color. @Option(name = "color") boolean color = true; @Option(name = "mode", shortName = 'm') String mode = "standard; // Supply a default just by setting the field. @Option(name = "port", shortName = 'p') int portNumber = 8888; // There's no need to offer a short name for rarely-used options. @Option(name = "timeout" ) double timeout = 1.0; @Option(name = "output-file", shortName = 'o' }) File output; // Multiple options are added to the collection. // The collection field itself must be non-null. @Option(name = "input-file", shortName = 'i') List<File> inputs = new ArrayList<File>(); } Options options = new Options(); List<String> posArgs = new OptionParser(options).parse("--input-file", "/tmp/file1.txt"); for (File inputFile : options.inputs) { if (!options.quiet) { ... } ... }ดูเพิ่มเติมที่:
- หน้าคน getopt(1)
- โมดูล "optparse" ของ Python (http://docs.python.org/library/optparse.html)
- POSIX "แนวทางการใช้ไวยากรณ์ของยูทิลิตี้" (http://www.opengroup.org/onlinepubs/000095399/baseefs/xbd_chap12.html#tag_12_02)
- GNU "มาตรฐานสำหรับอินเทอร์เฟซบรรทัดคำสั่ง" (http://www.gnu.org/prep/standards/standards.html#Command_002dLine-Interfaces)
ดูสิ่งนี้ด้วย:
สรุป
ผู้สร้างสาธารณะ | |
---|---|
ArgsOptionParser ( optionSources) ArgsOptionParser ( optionSources) สร้าง | |
ArgsOptionParser (Object... optionSources) สร้าง |
วิธีการสาธารณะ | |
---|---|
getInopOptions () ส่งกลับชุดของตัวเลือกที่ไม่ได้เปลี่ยนค่าเริ่มต้นใดๆ | |
static String | getOptionHelp (boolean importantOnly, Object optionObject) เอาต์พุตข้อความช่วยเหลือสำหรับฟิลด์ |
parse (String... args) แยกวิเคราะห์อาร์กิวเมนต์บรรทัดคำสั่ง 'args' ตั้งค่าฟิลด์ @Option ของ 'optionSource' ที่จัดเตรียมให้กับตัวสร้าง | |
parse ( args) parse ( args) วิธีแยก | |
parseBestEffort ( args) parseBestEffort ( args) วิธีการ | |
parseBestEffort ( args, boolean forceContinue) parseBestEffort ( args, boolean forceContinue) วิธี | |
parseBestEffort (String... args) | |
void | validateMandatoryOptions () ตรวจสอบว่าฟิลด์ทั้งหมดที่ถูกทำเครื่องหมายเป็นฟิลด์บังคับได้รับการตั้งค่าแล้ว |
ผู้สร้างสาธารณะ
ArgsOption Parser
public ArgsOptionParser (optionSources)
สร้าง ArgsOptionParser
สำหรับชุดของวัตถุ
พารามิเตอร์ | |
---|---|
optionSources |
พ่น | |
---|---|
ConfigurationException | หากวัตถุกำหนดค่าได้รับการกำหนดค่าไม่ถูกต้อง |
ArgsOption Parser
public ArgsOptionParser (Object... optionSources)
สร้าง ArgsOptionParser
สำหรับหนึ่งหรือหลายวัตถุ
พารามิเตอร์ | |
---|---|
optionSources | Object : วัตถุ config |
พ่น | |
---|---|
ConfigurationException | หากวัตถุกำหนดค่าได้รับการกำหนดค่าไม่ถูกต้อง |
วิธีการสาธารณะ
getInopOptions
publicgetInopOptions ()
ส่งกลับชุดของตัวเลือกที่ไม่ได้เปลี่ยนค่าเริ่มต้นใดๆ
ส่งคืน | |
---|---|
รับตัวเลือกช่วยเหลือ
public static String getOptionHelp (boolean importantOnly, Object optionObject)
เอาต์พุตข้อความช่วยเหลือสำหรับฟิลด์ Option
ทั้งหมดใน ตัวเลือกวัตถุ .
[-option_shortname, --option_name] [option_description] Default: [current option field's value in optionObject]ข้อความ 'Default..." จะถูกละเว้นหากฟิลด์ตัวเลือกว่างเปล่าหรือว่างเปล่า
พารามิเตอร์ | |
---|---|
importantOnly | boolean : ถ้า true ช่วยพิมพ์เฉพาะตัวเลือกที่สำคัญ |
optionObject | Object : วัตถุที่จะพิมพ์ข้อความช่วยเหลือ |
ส่งคืน | |
---|---|
String | สตริงที่มีข้อความช่วยเหลือที่ใช้งานง่ายสำหรับช่องตัวเลือกทั้งหมด |
แยกวิเคราะห์
publicparse (String... args)
แยกวิเคราะห์อาร์กิวเมนต์บรรทัดคำสั่ง 'args' ตั้งค่าฟิลด์ @Option ของ 'optionSource' ที่จัดเตรียมให้กับตัวสร้าง
พารามิเตอร์ | |
---|---|
args | String |
ส่งคืน | |
---|---|
ERROR(/List) ของอาร์กิวเมนต์ตำแหน่งที่เหลือหลังจากประมวลผลตัวเลือกทั้งหมด |
พ่น | |
---|---|
ConfigurationException | หากเกิดข้อผิดพลาดในการแยกวิเคราะห์อาร์กิวเมนต์ |
แยกวิเคราะห์
publicparse ( args)
วิธีแยก parse(String)
สำรองที่ใช้ ERROR(/List)
ของอาร์กิวเมนต์
พารามิเตอร์ | |
---|---|
args |
ส่งคืน | |
---|---|
ERROR(/List) ของอาร์กิวเมนต์ตำแหน่งที่เหลือหลังจากประมวลผลตัวเลือกทั้งหมด |
พ่น | |
---|---|
ConfigurationException | หากเกิดข้อผิดพลาดในการแยกวิเคราะห์อาร์กิวเมนต์ |
แยกวิเคราะห์ BestEffort
publicparseBestEffort ( args)
วิธีการ parseBestEffort(String)
สำรองที่ใช้ ERROR(/List)
ของอาร์กิวเมนต์
พารามิเตอร์ | |
---|---|
args |
ส่งคืน | |
---|---|
ERROR(/List) ของอาร์กิวเมนต์ที่เหลือ |
แยกวิเคราะห์ BestEffort
publicparseBestEffort ( args, boolean forceContinue)
วิธี parseBestEffort(String)
ทางเลือกที่รับข้อโต้แย้ง ERROR(/List)
และสามารถบังคับให้แยกวิเคราะห์ต่อไปจนจบ แม้ว่าบางข้อจะไม่แยกวิเคราะห์ก็ตาม
พารามิเตอร์ | |
---|---|
args | |
forceContinue | boolean : จริงหากควรแยกวิเคราะห์ต่อไปแม้ว่าบางข้อจะไม่แยกวิเคราะห์ก็ตาม |
ส่งคืน | |
---|---|
ERROR(/List) ของอาร์กิวเมนต์ที่เหลือ |
แยกวิเคราะห์ BestEffort
publicparseBestEffort (String... args)
parse(String)
เวอร์ชันความพยายามที่ดีที่สุด หากมีการโยน ConfigurationException ข้อยกเว้นนั้นจะถูกบันทึกภายใน และอาร์กิวเมนต์ที่เหลือ (รวมถึงอาร์กิวเมนต์ที่ทำให้ข้อยกเว้นถูกโยนทิ้ง) จะถูกส่งกลับ วิธีนี้ไม่โยน
พารามิเตอร์ | |
---|---|
args | String |
ส่งคืน | |
---|---|
ERROR(/List) ของอาร์กิวเมนต์ที่เหลือ |
ตรวจสอบตัวเลือกบังคับ
public void validateMandatoryOptions ()
ตรวจสอบว่าฟิลด์ทั้งหมดที่ถูกทำเครื่องหมายเป็นฟิลด์บังคับได้รับการตั้งค่าแล้ว
พ่น | |
---|---|
| com.android.tradefed.config.ConfigurationException |
ConfigurationException |