Thursday, September 3, 2020
OptionParser Command-Line Options the Ruby Way
OptionParser Command-Line Options the Ruby Way Ruby comes furnished with an amazing and adaptable instrument to parse order line choices, OptionParser. When you figure out how to utilize this, youll never return to glancing through ARGV physically. OptionParser has various highlights that make it very engaging Ruby software engineers. On the off chance that youve ever parsed choices by hand in Ruby or C, or with the getoptlong C work, youll perceive how invite a portion of these progressions are. OptionParser is DRY. You just need to compose the order line switch, its contentions, the code to run when its experienced, and the order line switch depiction once in your content. OptionParser will consequently produce help screens for you from this depiction, just as induce everything about the contention from its portrayal. For instance, it will know the record [FILE] alternative is discretionary and takes a solitary contention. Additionally, it will realize that [-no]-verbose is extremely two alternatives and will acknowledge both forms.OptionParser will naturally change over choices to a particular class. In the event that the alternative takes a whole number, it can change over any string gave the order line to a whole number. This eliminates a portion of the dreariness engaged with parsing order line options.Everything is contained. The entirety of the alternatives are in a similar spot, and the impact of the choice is directly nearby the definition for the choice. On the off chance that choices must be included, changed or somebody basically needs to perceive what they do, there is just one spot to look. When the order line is parsed, a solitary Hash or OpenStruct will hold the outcomes. Enough Already, Show Me Some Code So heres a straightforward case of how to utilize OptionParser. It doesnt utilize any of the propelled highlights, only the nuts and bolts. There are three alternatives, and one of them takes a boundary. The entirety of the alternatives are obligatory. There are the - v/verbose and - q/snappy choices, just as the - l/logfile FILE choice. Moreover, the content takes a rundown of documents autonomous of the alternatives. #!/usr/canister/env ruby # A content that will claim to resize various pictures require optparse # This hash will hold the entirety of the choices # parsed from the order line by # OptionParser. choices {} optparse OptionParser.new do|opts| à â # Set a pennant, showed at the top à â # of the assistance screen. à â opts.banner Usage: optparse1.rb [options] file1 file2 ... à â # Define the choices, and what they do à â options[:verbose] bogus à â opts.on( - v, verbose, Output more data ) do à â â â options[:verbose] genuine à â end à â options[:quick] bogus à â opts.on( - q, speedy, Perform the assignment rapidly ) do à â â â options[:quick] genuine à â end à â options[:logfile] nil à â opts.on( - l, logfile FILE, Write log to FILE ) do|file| à â â â options[:logfile] document à â end à â # This shows the assistance screen, all projects are à â # expected to have this choice. à â opts.on( - h, help, Display this screen ) do à â â â puts p icks à â â â exit à â end end # Parse the order line. Recall there are two structures # of the parse technique. The parse technique basically parses # ARGV, while the parse! technique parses ARGV and expels # any alternatives discovered there, just as any boundaries for # the choices. Whats left is the rundown of documents to resize. optparse.parse! puts Being verbose if options[:verbose] puts Being brisk if options[:quick] puts Logging to document #{options[:logfile]} if options[:logfile] ARGV.each do|f| à â puts Resizing picture #{f}... à â sleep 0.5 end Looking at the Code To begin with, the optparse library is required. Keep in mind, this isnt a diamond. It accompanies Ruby, so theres no compelling reason to introduce a pearl or require rubygems before optparse. There are two intriguing articles with regards to this content. The first is choices, proclaimed at the top-most degree. Its a basic void hash. At the point when choices are characterized, they compose their default esteems to this hash. For instance, the default conduct is for this content to not be verbose, so options[:verbose] is set to bogus. At the point when alternatives are experienced on the order line, theyll change the qualities in choices to mirror their impact. For instance, when - v/verbose is experienced, it will dole out consistent with options[:verbose]. The second intriguing item is optparse. This is simply the OptionParser object. At the point when you build this item, you pass it a square. This square is run during development and will assemble a rundown of choices in inner information structures, and prepare to parse everything. Its in this square all the enchantment occurs. You characterize all the alternatives here. Characterizing Options Every alternative follows a similar example. You initially compose the default an incentive into the hash. This will occur when the OptionParser is built. Next, you call the on technique, which characterizes the choice itself. There are a few types of this technique, yet just one is utilized here. Different structures permit you to characterize programmed type transformations and sets of qualities an alternative is limited to. The three contentions utilized here are the short structure, long structure, and depiction of the choice. The on technique will derive various things from the long structure. One thing is will induce is the nearness of any boundaries. On the off chance that there are any boundaries present on the alternative, it will pass them as boundaries to the square. In the event that the choice is experienced on the order line, the square went to the on technique is run. Here, the squares dont do a lot, they simply set qualities in the alternatives hash. More should be possible, for example, watching that a document alluded to exists, and so on. In the event that there are any mistakes, exemptions can be tossed from these squares. At long last, the order line is parsed. This occurs by calling the parse! technique on an OptionParser object. There are really two types of this strategy, parse and parse!. As the variant with the outcry point suggests, it is ruinous. In addition to the fact that it parses the order line, however it will expel any alternatives found from ARGV. This is something imperative, it will leave just the rundown of records provided after the alternatives in ARGV.
Subscribe to:
Post Comments (Atom)
No comments:
Post a Comment
Note: Only a member of this blog may post a comment.