/** * argparser – command line argument parser library * * Copyright © 2013 Mattias Andrée (maandree@member.fsf.org) * * This library is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this library. If not, see . */ #include #include #define true 1 #define false 0 #define null 0 #define ARGUMENTLESS 0 #define ARGUMENTED 1 #define VARIADIC 2 static void sort(char** list, long count); static long cmp(char* a, char* b); /** * Whether the Linux VT is being used */ long args_linuxvt; /** * The name of the executed command */ char* args_program; /** * Whether to free the member of `args_program` */ long args_program_dispose; /** * Short, single-line, description of the program */ char* args_dscription; /** * Formated, multi-line, usage text, `null` if none */ char* args_usage; /** * Long, multi-line, description of the program, `null` if none */ char* args_longdscription; /** * The error output stream */ FILE* args_out; /** * The passed arguments */ char** args_arguments; /** * The number of passed arguments */ long args_arguments_count; /** * The number of unrecognised arguments */ long args_unrecognised_count; /** * The concatination of `files` with blankspaces as delimiters, `null` if no files */ char* args_message; /** * The arguments passed that is not tied to an option */ char** args_files; /** * The number of elements in `args_files` */ long args_files_count; /** * Queue of objects that needs to be freed on dispose */ void** args_freequeue; // Options, in order // ArrayList