File: autocomp.h

package info (click to toggle)
gexec 0.4-1
  • links: PTS
  • area: main
  • in suites: jessie, jessie-kfreebsd, lenny, squeeze, wheezy
  • size: 104 kB
  • ctags: 59
  • sloc: ansic: 589; makefile: 55
file content (90 lines) | stat: -rw-r--r-- 3,352 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
/*
 * Name        : autocomp
 * Description : Auto-completion library
 * Version     : v0.4
 * 
 * Author      : Ferry Boender  <f.boender@electricmonk.nl>
 * Copyright   : (C) 2004, Ferry Boender
 * License     : General Public License. For more information and terms, see
 *               the COPYING file in this archive.
 *
 * Usage       : To compile:
 *                 /path-to-src/$ make
 *               To test:
 *                 /path-to-src/$ ./autocomp
 *               Or
 *                 /path-to-src/$ ./autocomp [argument]
 *                 
 *                 where argument is a (relative/absolute) command to be 
 *                 completed
 * Dependencies: glib
 * Purpose     : Provide a library which can be linked against any application
 *               and be used to perform autocompletion on file system oriented
 *               commands.
 * Revisions   : v0.2 [FB] First public release.
 *               v0.3 [FB] Whoops, the .h file got deleted,
 *               v0.4 [FB] Function names now shown in debug output,
 *                         Added ac_list_print function.
 *                         Added various sanity checks for NULL lists/etc.
 *                         Changed test cases in main().
 *               v0.5 [FB] Forgot to add ac_list_print to the .h file.
 *                         Removed the teststub from the main lib and placed it
 *                         in a seperate program called 'test'.
 * Remarks     : -
 * Todo        : -
 *
 */
#ifndef __AUTOCOMP_H__
#define __AUTOCOMP_H__

#include <stdio.h>
#include <stdlib.h>
#include <glib.h>
#include <string.h>
#include <dirent.h>

//#define _DEBUG

/* Name    : ac_path_get
 * Params  : -
 * Returns : A glib GList containing the broken down values in the PATH 
 *           environment variable.
 * Remarks : -
 */
GList *ac_path_get (void);

/* Name    : ac_list_free
 * Params  : A glib GList containing in the data section an hand-allocated 
 *           memory part.
 * Returns : NULL, the data and the GList itself are freed
 * Remarks : -
 */
GList *ac_list_free (GList *ac_list);

/* Name    : ac_list_get
 * Params  : A completion query which should be completed. Examples:
 *           "au"   (complete in current dir and path)
 *           "/et"  (complete in root dir)
 *           "../a" (comlete in parent dir)
 * Returns : A glib GList containing the possibilities for completing the qry.
 *           Example: 
 *           completion_qry = "au", current dir has file "autocomplete.c" and 
 *           "autocomplete". List is "ocomplete.c", "ocomplete".
 * Remarks : Use ac_list_free to deep-free mem used by list.
 */
GList *ac_list_get (char *completion_qry);

/* Name    : ac_list_print
 * Params  : ac_list: a glib GList containing the matches for a ompletion query
 *           completion_qry: A completion query which will only be used to 
 *           prepend it to the completion results.
 * Returns : -
 * Remarks : The matches that are printed are prepended with the command_qry, but
 *           the matches themself do not actually contain this prefix. 
 *           Ex: ac_list_print (list, "autoc") 
 *               prints 'autocomp' where 'autoc' is the completion query and 
 *               'omp' is the match.
 */
void ac_list_print (GList *ac_list, char *completion_qry);

#endif /* __AUTOCOMP_H__ */