2005-10-17 17:56:27 +00:00
/*
* Copyright ( C ) 2001 - 2004 Sistina Software , Inc . All rights reserved .
2011-01-13 14:51:32 +00:00
* Copyright ( C ) 2004 - 2011 Red Hat , Inc . All rights reserved .
2005-10-17 17:56:27 +00:00
*
* This file is part of LVM2 .
*
* This copyrighted material is made available to anyone wishing to use ,
* modify , copy , or redistribute it subject to the terms and conditions
2007-08-20 20:55:30 +00:00
* of the GNU Lesser General Public License v .2 .1 .
2005-10-17 17:56:27 +00:00
*
2007-08-20 20:55:30 +00:00
* You should have received a copy of the GNU Lesser General Public License
2005-10-17 17:56:27 +00:00
* along with this program ; if not , write to the Free Software Foundation ,
* Inc . , 59 Temple Place , Suite 330 , Boston , MA 02111 - 1307 USA
*/
2006-05-09 21:23:51 +00:00
# ifndef _LVM_EXEC_H
# define _LVM_EXEC_H
2005-10-17 17:56:27 +00:00
# include "lib.h"
2009-02-28 00:54:06 +00:00
struct cmd_context ;
2011-01-13 14:51:32 +00:00
/**
* Execute command with paramaters and return status
*
* \ param rstatus
* Returns command ' s exit status code .
*
* \ param sync_needed
* Bool specifying whether local devices needs to be synchronized
* before executing command .
* Note : You cannot synchronize devices within activation context .
*
* \ return
2013-08-06 14:26:00 +02:00
* 1 ( success ) or 0 ( failure ) .
2011-01-13 14:51:32 +00:00
*/
int exec_cmd ( struct cmd_context * cmd , const char * const argv [ ] ,
int * rstatus , int sync_needed ) ;
2009-02-24 15:48:00 +00:00
2013-08-06 14:27:37 +02:00
struct FILE ;
struct pipe_data {
FILE * fp ;
pid_t pid ;
} ;
/**
* popen ( ) like function to read - only output from executed command
* without running shell .
*
* \ param argv
* Arguments for execvp .
*
* \ param sync_needed
* Bool specifying whether local devices needs to be synchronized
* before executing command .
* Note : You cannot synchronize devices within activation context .
*
* \ param pdata
* Arguments to store data needed for pclose_exec ( ) .
*
* \ return
* 1 ( success ) or 0 ( failure ) .
*/
FILE * pipe_open ( struct cmd_context * cmd , const char * const argv [ ] ,
int sync_needed , struct pipe_data * pdata ) ;
int pipe_close ( struct pipe_data * pdata ) ;
2006-05-09 21:23:51 +00:00
# endif