[lxc-devel] [PATCH] Add getsubopt implementation for Android
Serge Hallyn
serge.hallyn at ubuntu.com
Wed Nov 18 02:20:54 UTC 2015
Quoting Stéphane Graber (stgraber at ubuntu.com):
> Signed-off-by: Stéphane Graber <stgraber at ubuntu.com>
Acked-by: Serge E. Hallyn <serge.hallyn at ubuntu.com>
> ---
> configure.ac | 4 +++
> src/include/getsubopt.c | 89 +++++++++++++++++++++++++++++++++++++++++++++++++
> src/include/getsubopt.h | 4 +++
> src/lxc/Makefile.am | 8 +++++
> src/lxc/lxc_copy.c | 6 ++++
> 5 files changed, 111 insertions(+)
> create mode 100644 src/include/getsubopt.c
> create mode 100644 src/include/getsubopt.h
>
> diff --git a/configure.ac b/configure.ac
> index beb53fe..447e404 100644
> --- a/configure.ac
> +++ b/configure.ac
> @@ -589,6 +589,10 @@ AC_CHECK_FUNCS([getline],
> AM_CONDITIONAL(HAVE_GETLINE, true)
> AC_DEFINE(HAVE_GETLINE,1,[Have getline]),
> AM_CONDITIONAL(HAVE_GETLINE, false))
> +AC_CHECK_FUNCS([getsubopt],
> + AM_CONDITIONAL(HAVE_GETSUBOPT, true)
> + AC_DEFINE(HAVE_GETSUBOPT,1,[Have getsubopt]),
> + AM_CONDITIONAL(HAVE_GETSUBOPT, false))
> AC_CHECK_FUNCS([fgetln],
> AM_CONDITIONAL(HAVE_FGETLN, true)
> AC_DEFINE(HAVE_FGETLN,1,[Have fgetln]),
> diff --git a/src/include/getsubopt.c b/src/include/getsubopt.c
> new file mode 100644
> index 0000000..b75497b
> --- /dev/null
> +++ b/src/include/getsubopt.c
> @@ -0,0 +1,89 @@
> +/*
> + * Android c-library does not have getsubopt,
> + * so code lifted from uClibc
> + * http://git.uclibc.org/uClibc/tree/libc/unistd/getsubopt.c
> + */
> +
> +/* Parse comma separate list into words.
> + Copyright (C) 1996, 1997, 1999, 2004 Free Software Foundation, Inc.
> + This file is part of the GNU C Library.
> + Contributed by Ulrich Drepper <drepper at cygnus.com>, 1996.
> + The GNU C Library is free software; you can redistribute it and/or
> + modify it under the terms of the GNU Lesser General Public
> + License as published by the Free Software Foundation; either
> + version 2.1 of the License, or (at your option) any later version.
> + The GNU C 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
> + Lesser General Public License for more details.
> + You should have received a copy of the GNU Lesser General Public
> + License along with the GNU C Library; if not, write to the Free
> + Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
> + 02111-1307 USA. */
> +
> +
> +#include <stdlib.h>
> +#include <string.h>
> +
> +char *strchrnul(const char *s, int c)
> +{
> + char *result;
> +
> + result = strchr( s, c );
> +
> + if( !result )
> + {
> + result = (char *)s + strlen( s );
> + }
> +
> + return( result );
> +}
> +
> +/* Parse comma separated suboption from *OPTIONP and match against
> + strings in TOKENS. If found return index and set *VALUEP to
> + optional value introduced by an equal sign. If the suboption is
> + not part of TOKENS return in *VALUEP beginning of unknown
> + suboption. On exit *OPTIONP is set to the beginning of the next
> + token or at the terminating NUL character. */
> +int
> +getsubopt (char **optionp, char *const *tokens, char **valuep)
> +{
> + char *endp, *vstart;
> + int cnt;
> +
> + if (**optionp == '\0')
> + return -1;
> +
> + /* Find end of next token. */
> + endp = strchrnul (*optionp, ',');
> +
> + /* Find start of value. */
> + vstart = memchr (*optionp, '=', endp - *optionp);
> + if (vstart == NULL)
> + vstart = endp;
> +
> + /* Try to match the characters between *OPTIONP and VSTART against
> + one of the TOKENS. */
> + for (cnt = 0; tokens[cnt] != NULL; ++cnt)
> + if (strncmp (*optionp, tokens[cnt], vstart - *optionp) == 0
> + && tokens[cnt][vstart - *optionp] == '\0')
> + {
> + /* We found the current option in TOKENS. */
> + *valuep = vstart != endp ? vstart + 1 : NULL;
> +
> + if (*endp != '\0')
> + *endp++ = '\0';
> + *optionp = endp;
> +
> + return cnt;
> + }
> +
> + /* The current suboption does not match any option. */
> + *valuep = *optionp;
> +
> + if (*endp != '\0')
> + *endp++ = '\0';
> + *optionp = endp;
> +
> + return -1;
> +}
> diff --git a/src/include/getsubopt.h b/src/include/getsubopt.h
> new file mode 100644
> index 0000000..b4e1622
> --- /dev/null
> +++ b/src/include/getsubopt.h
> @@ -0,0 +1,4 @@
> +#ifndef _getsubopt_h
> +#define _getsubopt_h
> +int getsubopt (char **optionp, char *const *tokens, char **valuep);
> +#endif
> diff --git a/src/lxc/Makefile.am b/src/lxc/Makefile.am
> index 72f1e9b..6953082 100644
> --- a/src/lxc/Makefile.am
> +++ b/src/lxc/Makefile.am
> @@ -38,6 +38,10 @@ noinst_HEADERS += ../include/getline.h
> endif
> endif
>
> +if !HAVE_GETSUBOPT
> +noinst_HEADERS += ../include/getsubopt.h
> +endif
> +
> sodir=$(libdir)
> # use PROGRAMS to avoid complains from automake
> so_PROGRAMS = liblxc.so
> @@ -240,6 +244,10 @@ lxc_usernsexec_SOURCES = lxc_usernsexec.c
> lxc_user_nic_SOURCES = lxc_user_nic.c network.c network.h
> lxc_checkpoint_SOURCES = lxc_checkpoint.c
>
> +if !HAVE_GETSUBOPT
> +lxc_copy_SOURCES += ../include/getsubopt.c ../include/getsubopt.h
> +endif
> +
> if HAVE_STATIC_LIBCAP
> sbin_PROGRAMS += init.lxc.static
>
> diff --git a/src/lxc/lxc_copy.c b/src/lxc/lxc_copy.c
> index 54f56f4..9678b50 100644
> --- a/src/lxc/lxc_copy.c
> +++ b/src/lxc/lxc_copy.c
> @@ -17,6 +17,8 @@
> */
>
> #define _GNU_SOURCE
> +#include "config.h"
> +
> #include <unistd.h>
> #include <getopt.h>
> #include <signal.h>
> @@ -44,6 +46,10 @@
> #include "utils.h"
> #include "bdev.h"
>
> +#ifndef HAVE_GETSUBOPT
> +#include <../include/getsubopt.h>
> +#endif
> +
> lxc_log_define(lxc_copy_ui, lxc);
>
> enum mnttype {
> --
> 1.9.1
>
> _______________________________________________
> lxc-devel mailing list
> lxc-devel at lists.linuxcontainers.org
> http://lists.linuxcontainers.org/listinfo/lxc-devel
More information about the lxc-devel
mailing list