/* Unix SMB/CIFS implementation. Samba readline wrapper implementation Copyright (C) Simo Sorce 2001 Copyright (C) Andrew Tridgell 2001 This program 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 program 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 program. If not, see . */ #include "includes.h" #ifdef HAVE_LIBREADLINE # ifdef HAVE_READLINE_READLINE_H # include # ifdef HAVE_READLINE_HISTORY_H # include # endif # else # ifdef HAVE_READLINE_H # include # ifdef HAVE_HISTORY_H # include # endif # else # undef HAVE_LIBREADLINE # endif # endif #endif #ifdef HAVE_NEW_LIBREADLINE # define RL_COMPLETION_CAST (rl_completion_func_t *) #else /* This type is missing from libreadline<4.0 (approximately) */ # define RL_COMPLETION_CAST #endif /* HAVE_NEW_LIBREADLINE */ static bool smb_rl_done; #if HAVE_LIBREADLINE /* * MacOS/X does not have rl_done in readline.h, but * readline.so has it */ extern int rl_done; #endif void smb_readline_done(void) { smb_rl_done = true; #if HAVE_LIBREADLINE rl_done = 1; #endif } /**************************************************************************** Display the prompt and wait for input. Call callback() regularly ****************************************************************************/ static char *smb_readline_replacement(const char *prompt, void (*callback)(void), char **(completion_fn)(const char *text, int start, int end)) { fd_set fds; char *line = NULL; struct timeval timeout; int fd = x_fileno(x_stdin); char *ret; /* Prompt might be NULL in non-interactive mode. */ if (prompt) { x_fprintf(x_stdout, "%s", prompt); x_fflush(x_stdout); } line = (char *)SMB_MALLOC(BUFSIZ); if (!line) { return NULL; } while (!smb_rl_done) { timeout.tv_sec = 5; timeout.tv_usec = 0; FD_ZERO(&fds); FD_SET(fd,&fds); if (sys_select_intr(fd+1,&fds,NULL,NULL,&timeout) == 1) { ret = x_fgets(line, BUFSIZ, x_stdin); if (ret == 0) { SAFE_FREE(line); } return ret; } if (callback) { callback(); } } SAFE_FREE(line); return NULL; } /**************************************************************************** Display the prompt and wait for input. Call callback() regularly. ****************************************************************************/ char *smb_readline(const char *prompt, void (*callback)(void), char **(completion_fn)(const char *text, int start, int end)) { char *ret; bool interactive; interactive = isatty(x_fileno(x_stdin)) || getenv("CLI_FORCE_INTERACTIVE"); if (!interactive) { return smb_readline_replacement(NULL, callback, completion_fn); } #if HAVE_LIBREADLINE /* Aargh! Readline does bizzare things with the terminal width that mucks up expect(1). Set CLI_NO_READLINE in the environment to force readline not to be used. */ if (getenv("CLI_NO_READLINE")) return smb_readline_replacement(prompt, callback, completion_fn); if (completion_fn) { /* The callback prototype has changed slightly between different versions of Readline, so the same function works in all of them to date, but we get compiler warnings in some. */ rl_attempted_completion_function = RL_COMPLETION_CAST completion_fn; } #if HAVE_DECL_RL_EVENT_HOOK if (callback) rl_event_hook = (Function *)callback; #endif ret = readline(prompt); if (ret && *ret) add_history(ret); #else ret = smb_readline_replacement(prompt, callback, completion_fn); #endif return ret; } /**************************************************************************** * return line buffer text ****************************************************************************/ const char *smb_readline_get_line_buffer(void) { #if defined(HAVE_LIBREADLINE) return rl_line_buffer; #else return NULL; #endif } /**************************************************************************** * set completion append character ***************************************************************************/ void smb_readline_ca_char(char c) { #if defined(HAVE_LIBREADLINE) rl_completion_append_character = c; #endif } /**************************************************************************** history ****************************************************************************/ int cmd_history(void) { #if defined(HAVE_LIBREADLINE) && defined(HAVE_HISTORY_LIST) HIST_ENTRY **hlist; int i; hlist = history_list(); for (i = 0; hlist && hlist[i]; i++) { DEBUG(0, ("%d: %s\n", i, hlist[i]->line)); } #else DEBUG(0,("no history without readline support\n")); #endif return 0; } ='n52' href='#n52'>52 53 54 55 56 57 58 59 60
/*   Converts XML docs and nodes to Python dicts and lists by
 *   using an XML file which describes the Python dict layout
 *
 *   Copyright 2009      David Sommerseth <davids@redhat.com>
 *
 *   This program 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 2 of the License, or
 *   (at your option) any later version.
 *
 *   This program 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 program; if not, write to the Free Software
 *   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
 *
 *   For the avoidance of doubt the "preferred form" of this code is one which
 *   is in an open unpatent encumbered format. Where cryptographic key signing
 *   forms part of the process of creating an executable the information
 *   including keys needed to generate an equivalently functional executable
 *   are deemed to be part of the source code.
 */

#ifndef _XMLPYTHONIZER_H
#define _XMLPYTHONIZER_H

typedef enum ptzTYPES_e { ptzCONST, ptzSTR, ptzINT, ptzFLOAT, ptzBOOL,
                          ptzLIST_STR, ptzLIST_INT, ptzLIST_FLOAT, ptzLIST_BOOL,
                          ptzDICT, ptzLIST_DICT } ptzTYPES;

typedef struct ptzMAP_s {
        char *rootpath;         // XML root path for the data - if NULL, XML document is the root document.

        ptzTYPES type_key;      // Valid types: ptzCONST, ptzSTR, ptzINT, ptzFLOAT
        char *key;              // for ptzCONST key contains a static string, other types an XPath to XML data
        ptzTYPES type_value;
        char *value;            // for ptzCONST key contains a static string,
                                // the rest of types, an XPath to XML data
        int fixed_list_size;    // Only to be used on lists
        char *list_index ;      // Only to be used on fixed lists
        int emptyIsNone;        // If set to 1, empty input (right trimmed) strings sets the result to Py_None
        char *emptyValue;       // If set, this value will be used when input is empty
        struct ptzMAP_s *child; // Only used for type_value == (ptzDICT || ptzLIST_DICT)
        struct ptzMAP_s *next;  // Pointer chain

} ptzMAP;

xmlNode *dmiMAP_GetRootElement(xmlDoc *mapdoc);
ptzMAP *dmiMAP_ParseMappingXML_TypeID(xmlDoc *xmlmap, int typeid);
ptzMAP *dmiMAP_ParseMappingXML_GroupName(xmlDoc *xmlmap, const char *mapname);
#define ptzmap_Free(ptr) { ptzmap_Free_func(ptr); ptr = NULL; }
void ptzmap_Free_func(ptzMAP *ptr);

PyObject *pythonizeXMLdoc(ptzMAP *map, xmlDoc *xmldoc);
PyObject *pythonizeXMLnode(ptzMAP *map, xmlNode *nodes);

#endif // _XMLPYTHONIZER_H