Skip to content

Commit

Permalink
libmbcommon: Replace libiconv with bionic iconv
Browse files Browse the repository at this point in the history
Signed-off-by: Andrew Gunnerson <[email protected]>
  • Loading branch information
chenxiaolong committed Jul 4, 2018
1 parent fd53834 commit d9356ad
Show file tree
Hide file tree
Showing 12 changed files with 529 additions and 567 deletions.
1 change: 0 additions & 1 deletion cmake/Dependencies.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,6 @@ if(${MBP_BUILD_TARGET} STREQUAL desktop)
include(cmake/dependencies/zlib.cmake)
elseif(${MBP_BUILD_TARGET} STREQUAL android-app)
include(cmake/dependencies/googletest.cmake)
include(cmake/dependencies/iconv.cmake)
include(cmake/dependencies/libarchive.cmake)
include(cmake/dependencies/liblzma.cmake)
include(cmake/dependencies/lz4.cmake)
Expand Down
1 change: 0 additions & 1 deletion cmake/dependencies/iconv.cmake

This file was deleted.

31 changes: 0 additions & 31 deletions cmake/modules/FindIconv.cmake

This file was deleted.

27 changes: 19 additions & 8 deletions libmbcommon/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,13 @@ if("${CMAKE_CXX_COMPILER_ID}" STREQUAL "Clang")
)
endif()

set_source_files_properties(
src/external/iconv.cpp
PROPERTIES
COMPILE_FLAGS
"-Wno-conversion -Wno-sign-conversion -Wno-shadow"
)

set(variants)

if(MBP_TARGET_HAS_BUILDS)
Expand Down Expand Up @@ -63,7 +70,18 @@ foreach(variant ${variants})
${CMAKE_CURRENT_BINARY_DIR}/gen/version.cpp
)

if(WIN32)
if(${MBP_BUILD_TARGET} STREQUAL android-app)
target_sources(
${lib_target}
PRIVATE
src/external/iconv.cpp
)
target_compile_definitions(
${lib_target}
PRIVATE
-DUSE_EXTERNAL_ICONV
)
elseif(WIN32)
target_sources(
${lib_target}
PRIVATE
Expand Down Expand Up @@ -102,13 +120,6 @@ foreach(variant ${variants})
$<$<STREQUAL:${variant},shared>:interface.mbcommon.dynamic-link>
)

if(TARGET Iconv::Iconv)
target_link_libraries(
${lib_target}
PRIVATE Iconv::Iconv
)
endif()

# Install shared library
if(${variant} STREQUAL shared)
install(
Expand Down
7 changes: 7 additions & 0 deletions libmbcommon/external.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
---
- files:
- include/mbcommon/external/bionic_mbstate.h
- include/mbcommon/external/iconv.h
- src/external/iconv.cpp
repo: https://android.googlesource.com/platform/bionic
commit: 50acae8f2ae017c49b1d616e93ce9f97f6b3d118
75 changes: 75 additions & 0 deletions libmbcommon/include/mbcommon/external/bionic_mbstate.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,75 @@
/*
* Copyright (C) 2014 The Android Open Source Project
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in
* the documentation and/or other materials provided with the
* distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
* OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*/

#ifndef _BIONIC_MBSTATE_H
#define _BIONIC_MBSTATE_H

#include <errno.h>
#include <wchar.h>

__BEGIN_DECLS

/*
* These return values are specified by POSIX for multibyte conversion
* functions.
*/
#define __MB_ERR_ILLEGAL_SEQUENCE static_cast<size_t>(-1)
#define __MB_ERR_INCOMPLETE_SEQUENCE static_cast<size_t>(-2)

#define __MB_IS_ERR(rv) (rv == __MB_ERR_ILLEGAL_SEQUENCE || \
rv == __MB_ERR_INCOMPLETE_SEQUENCE)

static inline __wur size_t mbstate_bytes_so_far(const mbstate_t* ps) {
return
(ps->__seq[2] != 0) ? 3 :
(ps->__seq[1] != 0) ? 2 :
(ps->__seq[0] != 0) ? 1 : 0;
}

static inline void mbstate_set_byte(mbstate_t* ps, int i, char byte) {
ps->__seq[i] = static_cast<uint8_t>(byte);
}

static inline __wur uint8_t mbstate_get_byte(const mbstate_t* ps, int n) {
return ps->__seq[n];
}

static inline __wur size_t mbstate_reset_and_return_illegal(int _errno, mbstate_t* ps) {
errno = _errno;
*(reinterpret_cast<uint32_t*>(ps->__seq)) = 0;
return __MB_ERR_ILLEGAL_SEQUENCE;
}

static inline __wur size_t mbstate_reset_and_return(int _return, mbstate_t* ps) {
*(reinterpret_cast<uint32_t*>(ps->__seq)) = 0;
return _return;
}

__END_DECLS

#endif // _BIONIC_MBSTATE_H
46 changes: 46 additions & 0 deletions libmbcommon/include/mbcommon/external/iconv.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
/*
* Copyright (C) 2017 The Android Open Source Project
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in
* the documentation and/or other materials provided with the
* distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
* OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*/

#ifndef _ICONV_H_
#define _ICONV_H_

#include <sys/cdefs.h>
#include <sys/types.h>

__BEGIN_DECLS

struct __iconv_t;
typedef struct __iconv_t* iconv_t;

iconv_t iconv_open(const char* __src_encoding, const char* __dst_encoding) __INTRODUCED_IN(28);
size_t iconv(iconv_t __converter, char** __src_buf, size_t* __src_bytes_left, char** __dst_buf, size_t* __dst_bytes_left) __INTRODUCED_IN(28);
int iconv_close(iconv_t __converter) __INTRODUCED_IN(28);

__END_DECLS

#endif
Loading

0 comments on commit d9356ad

Please sign in to comment.