> On Nov 3, 2014, at 5:42 PM, Neil Horman <nhorman at tuxdriver.com> wrote:
> 
> On Mon, Nov 03, 2014 at 03:26:50PM -0800, Stephen Hemminger wrote:
>> On Mon, 3 Nov 2014 16:50:15 +0000
>> "Wiles, Roger Keith" <keith.wiles at windriver.com> wrote:
>> 
>>> 
>>>> On Nov 3, 2014, at 10:06 AM, Neil Horman <nhorman at tuxdriver.com> wrote:
>>>> 
>>>> On Mon, Nov 03, 2014 at 02:25:51PM +0000, Wiles, Roger Keith wrote:
>>>>> 
>>>>>> On Nov 3, 2014, at 8:16 AM, Bruce Richardson <bruce.richardson at 
>>>>>> intel.com> wrote:
>>>>>> 
>>>>>> On Mon, Nov 03, 2014 at 02:08:46PM +0000, Wiles, Roger Keith wrote:
>>>>>>> 
>>>>>>>> On Nov 3, 2014, at 4:41 AM, Bruce Richardson <bruce.richardson at 
>>>>>>>> intel.com> wrote:
>>>>>>>> 
>>>>>>>> On Sun, Nov 02, 2014 at 04:28:28PM -0600, Keith Wiles wrote:
>>>>>>>>> Allow for a external parser to handle the command line if the
>>>>>>>>> command is not found and the developer has called the routine
>>>>>>>>> int cmdline_set_external_parser(struct cmdline * cl,
>>>>>>>>>                             cmdline_external_parser_t parser);
>>>>>>>>> function to set the function pointer.
>>>>>>>>> 
>>>>>>>>> The function for the external parser function should return 
>>>>>>>>> CMDLINE_PARSE_NOMATCH
>>>>>>>>> if not able to match the command requested or zero is handled.
>>>>>>>>> 
>>>>>>>>> Prototype of external routine:
>>>>>>>>> int (*cmdline_external_parser_t)(struct cmdline * cl, const char * 
>>>>>>>>> buy);
>>>>>>>>> 
>>>>>>>>> Signed-off-by: Keith Wiles <keith.wiles at windriver.com>
>>>>>>>> 
>>>>>>>> Hi Keith,
>>>>>>>> 
>>>>>>>> what is the expected use case for this? Is it for embedding other 
>>>>>>>> programming languages alongside the existing DPDK command-line or some 
>>>>>>>> other purpose? [Perhaps the use case could be called out in the patch 
>>>>>>>> description]
>>>>>>> 
>>>>>>> Hi Bruce,
>>>>>>> 
>>>>>>> I guess the external parser could be used for other programming 
>>>>>>> languages, but the case I was looking at was to provide a default 
>>>>>>> escape from the command line parser to allow my application to handle 
>>>>>>> the commands not understood by the parser. Now that you point it out I 
>>>>>>> could use something like ?%<line-of-script-code>? to execute a single 
>>>>>>> line of script code, which is a good idea (thanks).
>>>>>>> 
>>>>>>> One case I am looking at is when you want to execute a command and do 
>>>>>>> not want to add the support into the commands.c file for every possible 
>>>>>>> command. Take the case where you have a bunch of scripts (Lua) in a 
>>>>>>> directory much like a bin directory. Then you could type foo.lua or foo 
>>>>>>> on the command line and execute the foo.lua having the application 
>>>>>>> detect you want to load and run a Lua script after it has finished 
>>>>>>> parsing for the builtin commands.
>>>>>>> 
>>>>>>> For Pktgen I had to add a command called ?run <filename> <args?>? to 
>>>>>>> support running a script with arguments. I also needed to add a 
>>>>>>> argvlist type to cmdline to not error out on that command and split up 
>>>>>>> the args into a argv list like format. (Maybe I need to submit that 
>>>>>>> code??) It seemed more straight forward to just pass the command line 
>>>>>>> to the application to run the command. I understand that seems like a 
>>>>>>> minor point, but it does make it easier to use and to support the 
>>>>>>> features I want to support in my PoC.
>>>>>>> 
>>>>>>> Using this method you can just type the name instead of something like 
>>>>>>> ?run foo.lua? or just ?run foo? and let the code figure out what to 
>>>>>>> run. I have more plans for this features as well and have not finished 
>>>>>>> the basic PoC yet. If you want a peek I can show you what I am working 
>>>>>>> on currently.
>>>>>>> 
>>>>>>> Does this help and do I really need to add all of this to the commit 
>>>>>>> message :-)
>>>>>>> 
>>>>>> Thanks for the explanation. However, if you are looking to have the 
>>>>>> application handle a bunch of commands itself, why does it need to use 
>>>>>> the commandline library at all? Why not just have the app handle all the 
>>>>>> commands instead of some of them?
>>>>> 
>>>>> I guess that would be reasonable, but then I would have to add support 
>>>>> for all of the command line parsing being done in the cmdline code. Think 
>>>>> of this as a default case for the parser and to me that makes more sense 
>>>>> then just doing my own command line design. In the cmdline code you guys 
>>>>> provided is a lot of features like history, control key support, arg 
>>>>> parsing (IP, MAC) and many others. I would rather not have to write that 
>>>>> code myself.
>>>>> 
>>>>> The default case is the same behavior today, with giving a no match error 
>>>>> unless they add the external parser.
>>>> 
>>>> It seems alot simpler than that to me.  Looking at the test applications, 
>>>> the
>>>> command line parser expects the application to create an array of
>>>> cmdline_parse_ctx_t structures to support new option parsing.  If your 
>>>> goal is
>>>> to support other languages, it seems to make more sense to just use foreign
>>>> language bindings to merge your coding language support with the DPDK
>>>> (ostensibly you will already have to do that if you want to use other 
>>>> parts of
>>>> the DPDK).
>>> Hi Neil,
>>> 
>>> A true language binding like Lua or one of those other languages :-) you 
>>> are correct to believe binding directly using ?C? code is the right 
>>> solution . In Pktgen I use Lua as the direct language binding and extend 
>>> Lua with specific Pktgen functions.
>>> 
>>> What I am doing here is to add a default case to cmdline code, which just 
>>> happens to allow me to parse the cmdline in the application. Being able to 
>>> execute say a line of script code is not really the requirement IMO. Being 
>>> able to extend the cmdline code with a default case is a good feature and 
>>> allows the developer to extend cmdline for some simple cases. The cmdline 
>>> code is kind of simple, but does require a fair amount of structures, code 
>>> and understanding to write a complex extendable command line interface. It 
>>> does seem hard to find a clean, simple and usable embedded command line 
>>> code base is not very easy to locate. 
>>> 
>>> Adding a true language binding really requires using code to extend the 
>>> language as I did with Lua and Pktgen. It could have been done with any 
>>> language I just picked Lua, but the patch does not really add support for a 
>>> language other then giving some support for someone to handle the no_match 
>>> case.
>>> 
>>> The use case for this feature is not just for Pktgen, but another solution 
>>> I hope everyone will find useful when I get it more complete.
>>> 
>>> Thanks
>>> ++Keith
>>> 
>>> PS. on a different topic I was thinking about suggesting and writing a 
>>> patch to add Lua with DPDK specific binding and extensions. (also allowing 
>>> those `other` languages too :-) Being able to use a scripting language and 
>>> be able to call DPDK API?s could be useful. How useful not sure at this 
>>> time. (If you want to talk about this topic please start a new thread).
>>>> 
>>>> Am I missing something?
>>>> Neil
>>>> 
>>>> 
>>>>>> 
>>>>>> /Bruce
>>>>> 
>>>>> Keith Wiles, Principal Technologist with CTO office, Wind River mobile 
>>>>> 972-213-5533
>>> 
>>> Keith Wiles, Principal Technologist with CTO office, Wind River mobile 
>>> 972-213-5533
>> 
>> I wouldn't invest a lot of sweat in the command line parser.
>> The one in the DPDK is "good enough" for what it needs to do, but really 
>> isn't
>> very complete and flexible. Seems like the kind of thing that doesn't really 
>> even
>> need to be in DPDK. Better off being part of some other library.
>> 
> Well, something needs to be there to parse the libraries' common options, 
> though
> I agree, making eal_cmdline just a registration frontend to getopt or
> getopt_long would be sufficient.

Until we have a better command line solution, which I think would be great, but 
in the mean time I would like to see this patch applied if no one has a 
technical reason or better suggestion.

I think this patch is fairly simple and I think we need a way to handle the 
default case. If someone could please review the patch, that would be great.

++Keith 

> 
> Neil
> 

Keith Wiles, Principal Technologist with CTO office, Wind River mobile 
972-213-5533

Reply via email to