ReadLine自动补全分析

若用户在使用GNU 的ReadLine库,则可以在开发的CLI中使用Tab键对命令自动搜索匹配项并补全,其后台运行机制分析如下:

1.首先看函数   rl_completion_func_t * rl_attempted_completion_function

gnu帮助文档对其描述如下:

Variable: rl_completion_func_t * rl_attempted_completion_function

A pointer to an alternative function to create matches. The function is called with text, start, and end. start and end are indices in rl_line_buffer defining the boundaries of text, which is a character string. If this function exists and returns NULL, or if this variable is set to NULL, then rl_complete() will call the value of rl_completion_entry_function to generate matches, otherwise the array of strings returned will be used. If this function sets the rl_attempted_completion_over variable to a non-zero value, Readline will not perform its default completion even if this function returns no matches.

  • 首先,这是一个可选的创建匹配字符串的函数,如果该函数指针未赋值(即为空)或者它存在但是返回NULL,那么创建匹配项系统库函数 rl_complete()会调用函数 rl_completion_entry_function() 来完成创建匹配项。否则,该函数会生效并替换完成系统库函数 rl_complete()的功能。
  • 其次,该函数包含三个参数:char *text, int start, int end。text表示用户输入有待匹配的不完整字符串,start 和 end 表示rl_line_buffer 的界限。

2.再看函数 char ** rl_completion_matches (const char *text, rl_compentry_func_t *entry_func)

gnu帮助文档对其描述如下:

Function: char ** rl_completion_matches (const char *text, rl_compentry_func_t *entry_func)

Returns an array of strings which is a list of completions for text. If there are no completions, returns NULL. The first entry in the returned array is the substitution for text. The remaining entries are the possible completions. The array is terminated with a NULL pointer.

entry_func is a function of two args, and returns a char *. The first argument is text. The second is a state argument; it is zero on the first call, and non-zero on subsequent calls. entry_func returns a NULL pointer to the caller when there are no more matches.

该函数会完成命令匹配项的搜索和创建,它包含两个参数,text表示带匹配的字符串,函数指针参数entry_func则会完成最终的匹配项创建,返回值为匹配的字符串数组(且第一个字符串为text本身)。

entry_func的函数原型为: char *rl_compentry_func_t (const char *, int);

第一个参数为待匹配字符串,第二个整型参数表示多次调用时的状态值:第一次调用时为0,后续调用时为正整数。需要指出的是该函数的返回字符串必须通过malloc的方式分配产生,ReadLine库函数匹配完成后会通过free释放掉,若为静态变量或全局变量则会导致释放失败,官方给出的描述如下:

The generator function is called repeatedly from rl_completion_matches(), returning a string each time. The arguments to the generator function are text and state. text is the partial word to be completed. state is zero the first time the function is called, allowing the generator to perform any necessary initialization, and a positive non-zero integer for each subsequent call. The generator function returns (char *)NULL to inform rl_completion_matches() that there are no more possibilities left. Usually the generator function computes the list of possible completions when state is zero, and returns them one at a time on subsequent calls. Each string the generator function returns as a match must be allocated with malloc(); Readline frees the strings when it has finished with them. Such a generator function is referred to as an application-specific completion function.

至此,Tab匹配过程完成,总结如下:

参考gnu帮助链接:

http://tiswww.case.edu/php/chet/readline/readline.html#SEC47

GNU ReadLine help链接

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值