Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
P
protobuf
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
protobuf
Commits
6f2bc19b
Commit
6f2bc19b
authored
Apr 08, 2015
by
Kun Zhang
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add cross-compilation for Windows on Linux using MinGW. Check library dependencies of artifact
parent
c6792363
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
65 additions
and
7 deletions
+65
-7
build-protoc.sh
protoc-artifacts/build-protoc.sh
+65
-7
No files found.
protoc-artifacts/build-protoc.sh
View file @
6f2bc19b
...
@@ -25,7 +25,8 @@ E_ASSERT_FAILED=99
...
@@ -25,7 +25,8 @@ E_ASSERT_FAILED=99
# Usage:
# Usage:
fail
()
fail
()
{
{
echo
"Error:
$1
"
echo
"ERROR:
$1
"
echo
exit
$E_ASSERT_FAILED
exit
$E_ASSERT_FAILED
}
}
...
@@ -49,8 +50,11 @@ assertEq ()
...
@@ -49,8 +50,11 @@ assertEq ()
# Usage: checkArch <path-to-protoc>
# Usage: checkArch <path-to-protoc>
checkArch
()
checkArch
()
{
{
echo
echo
"Checking for file format ..."
if
[[
"
$OS
"
==
windows
||
"
$OS
"
==
linux
]]
;
then
if
[[
"
$OS
"
==
windows
||
"
$OS
"
==
linux
]]
;
then
format
=
"
$(
objdump
-f
"
$1
"
|
grep
-o
"file format .*$"
|
grep
-o
"[^ ]*$"
)
"
format
=
"
$(
objdump
-f
"
$1
"
|
grep
-o
"file format .*$"
|
grep
-o
"[^ ]*$"
)
"
echo
Format
=
$format
if
[[
"
$OS
"
==
linux
]]
;
then
if
[[
"
$OS
"
==
linux
]]
;
then
if
[[
"
$ARCH
"
==
x86_32
]]
;
then
if
[[
"
$ARCH
"
==
x86_32
]]
;
then
assertEq
$format
"elf32-i386"
$LINENO
assertEq
$format
"elf32-i386"
$LINENO
...
@@ -71,6 +75,7 @@ checkArch ()
...
@@ -71,6 +75,7 @@ checkArch ()
fi
fi
elif
[[
"
$OS
"
==
osx
]]
;
then
elif
[[
"
$OS
"
==
osx
]]
;
then
format
=
"
$(
file
-b
"
$1
"
|
grep
-o
"[^ ]*$"
)
"
format
=
"
$(
file
-b
"
$1
"
|
grep
-o
"[^ ]*$"
)
"
echo
Format
=
$format
if
[[
"
$ARCH
"
==
x86_32
]]
;
then
if
[[
"
$ARCH
"
==
x86_32
]]
;
then
assertEq
$format
"i386"
$LINENO
assertEq
$format
"i386"
$LINENO
elif
[[
"
$ARCH
"
==
x86_64
]]
;
then
elif
[[
"
$ARCH
"
==
x86_64
]]
;
then
...
@@ -79,8 +84,45 @@ checkArch ()
...
@@ -79,8 +84,45 @@ checkArch ()
fail
"Unsupported arch:
$ARCH
"
fail
"Unsupported arch:
$ARCH
"
fi
fi
else
else
fail
"Unsupported system:
$
(
uname
)
"
fail
"Unsupported system:
$
OS
"
fi
fi
echo
}
# Checks the dependencies of the artifact. Artifacts should only depend on
# system libraries.
# Usage: checkDependencies <path-to-protoc>
checkDependencies
()
{
if
[[
"
$OS
"
==
windows
]]
;
then
dump_cmd
=
'objdump -x '
"
$1
"
' | fgrep "DLL Name"'
white_list
=
"KERNEL32
\.
dll
\|
msvcrt
\.
dll"
elif
[[
"
$OS
"
==
linux
]]
;
then
dump_cmd
=
'ldd '
"
$1
"
if
[[
"
$ARCH
"
==
x86_32
]]
;
then
white_list
=
"linux-gate
\.
so
\.
1
\|
libpthread
\.
so
\.
0
\|
libm
\.
so
\.
6
\|
libc
\.
so
\.
6
\|
ld-linux
\.
so
\.
2"
elif
[[
"
$ARCH
"
==
x86_64
]]
;
then
white_list
=
"linux-vdso
\.
so
\.
1
\|
libpthread
\.
so
\.
0
\|
libm
\.
so
\.
6
\|
libc
\.
so
\.
6
\|
ld-linux-x86-64
\.
so
\.
2"
fi
elif
[[
"
$OS
"
==
osx
]]
;
then
dump_cmd
=
'otool -L '
"
$1
"
white_list
=
"libz
\.
1
\.
dylib
\|
libc++
\.
1
\.
dylib
\|
libSystem
\.
B
\.
dylib"
fi
if
[[
-z
"
$white_list
"
||
-z
"
$dump_cmd
"
]]
;
then
fail
"Unsupported platform
$OS
-
$ARCH
."
fi
echo
"Checking for expected dependencies ..."
eval
$dump_cmd
|
grep
-i
"
$white_list
"
||
fail
"doesn't show any expected dependencies"
echo
"Checking for unexpected dependencies ..."
eval
$dump_cmd
|
grep
-i
-v
"
$white_list
"
ret
=
$?
if
[[
$ret
==
0
]]
;
then
fail
"found unexpected dependencies (listed above)."
elif
[[
$ret
!=
1
]]
;
then
fail
"Error when checking dependencies."
fi
# grep returns 1 when "not found", which is what we expect
echo
"Dependencies look good."
echo
}
}
############################################################################
############################################################################
...
@@ -100,6 +142,7 @@ fi
...
@@ -100,6 +142,7 @@ fi
# Override the default value set in configure.ac that has '-g' which produces
# Override the default value set in configure.ac that has '-g' which produces
# huge binary.
# huge binary.
CXXFLAGS
=
"-DNDEBUG"
CXXFLAGS
=
"-DNDEBUG"
LDFLAGS
=
""
if
[[
"
$(
uname
)
"
==
CYGWIN
*
]]
;
then
if
[[
"
$(
uname
)
"
==
CYGWIN
*
]]
;
then
assertEq
"
$OS
"
windows
$LINENO
assertEq
"
$OS
"
windows
$LINENO
...
@@ -116,7 +159,7 @@ elif [[ "$(uname)" == MINGW32* ]]; then
...
@@ -116,7 +159,7 @@ elif [[ "$(uname)" == MINGW32* ]]; then
assertEq
"
$OS
"
windows
$LINENO
assertEq
"
$OS
"
windows
$LINENO
assertEq
"
$ARCH
"
x86_32
$LINENO
assertEq
"
$ARCH
"
x86_32
$LINENO
elif
[[
"
$(
uname
)
"
==
Linux
*
]]
;
then
elif
[[
"
$(
uname
)
"
==
Linux
*
]]
;
then
assertEq
"
$OS
"
linux
$LINENO
if
[[
"
$OS
"
==
linux
]]
;
then
if
[[
"
$ARCH
"
==
x86_64
]]
;
then
if
[[
"
$ARCH
"
==
x86_64
]]
;
then
CXXFLAGS
=
"
$CXXFLAGS
-m64"
CXXFLAGS
=
"
$CXXFLAGS
-m64"
elif
[[
"
$ARCH
"
==
x86_32
]]
;
then
elif
[[
"
$ARCH
"
==
x86_32
]]
;
then
...
@@ -124,6 +167,21 @@ elif [[ "$(uname)" == Linux* ]]; then
...
@@ -124,6 +167,21 @@ elif [[ "$(uname)" == Linux* ]]; then
else
else
fail
"Unsupported arch:
$ARCH
"
fail
"Unsupported arch:
$ARCH
"
fi
fi
elif
[[
"
$OS
"
==
windows
]]
;
then
# Cross-compilation for Windows
# TODO(zhangkun83) MinGW 64 always adds dependency on libwinpthread-1.dll,
# which is undesirable for repository deployment.
CONFIGURE_ARGS
=
"
$CONFIGURE_ARGS
"
if
[[
"
$ARCH
"
==
x86_64
]]
;
then
CONFIGURE_ARGS
=
"
$CONFIGURE_ARGS
--host=x86_64-w64-mingw32"
elif
[[
"
$ARCH
"
==
x86_32
]]
;
then
CONFIGURE_ARGS
=
"
$CONFIGURE_ARGS
--host=i686-w64-mingw32"
else
fail
"Unsupported arch:
$ARCH
"
fi
else
fail
"Cannot build
$OS
on
$(
uname
)
"
fi
elif
[[
"
$(
uname
)
"
==
Darwin
*
]]
;
then
elif
[[
"
$(
uname
)
"
==
Darwin
*
]]
;
then
assertEq
"
$OS
"
osx
$LINENO
assertEq
"
$OS
"
osx
$LINENO
if
[[
"
$ARCH
"
==
x86_64
]]
;
then
if
[[
"
$ARCH
"
==
x86_64
]]
;
then
...
@@ -137,19 +195,19 @@ else
...
@@ -137,19 +195,19 @@ else
fail
"Unsupported system:
$(
uname
)
"
fail
"Unsupported system:
$(
uname
)
"
fi
fi
export
CXXFLAGS
# Statically link libgcc and libstdc++.
# Statically link libgcc and libstdc++.
# -s to produce stripped binary.
# -s to produce stripped binary.
# And they don't work under Mac.
# And they don't work under Mac.
if
[[
"
$OS
"
!=
osx
]]
;
then
if
[[
"
$OS
"
!=
osx
]]
;
then
export
LDFLAGS
=
"
-static-libgcc -static-libstdc++ -s"
LDFLAGS
=
"
$LDFLAGS
-static-libgcc -static-libstdc++ -s"
fi
fi
export
CXXFLAGS LDFLAGS
TARGET_FILE
=
target/protoc.exe
TARGET_FILE
=
target/protoc.exe
cd
"
$WORKING_DIR
"
/..
&&
./configure
$CONFIGURE_ARGS
&&
cd
"
$WORKING_DIR
"
/..
&&
./configure
$CONFIGURE_ARGS
&&
cd
src
&&
make clean
&&
make
$MAKE_TARGET
&&
cd
src
&&
make clean
&&
make
$MAKE_TARGET
&&
cd
"
$WORKING_DIR
"
&&
mkdir
-p
target
&&
cd
"
$WORKING_DIR
"
&&
mkdir
-p
target
&&
(
cp
../src/protoc
$TARGET_FILE
||
cp
../src/protoc.exe
$TARGET_FILE
)
&&
(
cp
../src/protoc
$TARGET_FILE
||
cp
../src/protoc.exe
$TARGET_FILE
)
&&
checkArch
$TARGET_FILE
checkArch
$TARGET_FILE
&&
checkDependencies
$TARGET_FILE
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment