2006-11-23 12:15:17 +00:00
#!/bin/sh
2012-03-25 11:46:15 +00:00
# OE-Core Build Environment Setup Script
2006-11-23 12:15:17 +00:00
#
2011-04-21 11:26:25 +00:00
# Copyright (C) 2006-2011 Linux Foundation
2006-11-23 12:15:17 +00:00
#
# 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
2010-11-24 22:25:28 +00:00
# It is assumed OEROOT is already defined when this is called
if [ -z "$OEROOT" ]; then
echo >&2 "Error: OEROOT is not defined!"
oe-init-build-env, scripts/oe-buildenv-internal: add error detecting for $BDIR
[YOCTO #671]
"readlink -f" in Ubuntu 10.04 is buggy: it doesn't ignore a trailing / (e.g.,
"readlink -f /tmp/non-existent-dir/" returns nothing, but according to
http://www.gnu.org/s/coreutils/manual/coreutils.pdf it should do that --
hence we get bug 671. It seems Ubuntu 10.10 or even later Ubuntu 11.04,
and other Linux distributions(e.g., Open Suse 11.4) haven't such an issue.
So I think we should detect this and ask Ubuntu 10.04 users to avoid supply
a path with trailing slash here.
Moreever, I also add the detection of non-existent path, e.g.,
source oe-init-build-env /non-existent-dir/build
can be detected and we'll print an error msg.
And, if we get errors in oe-buildenv-internal, we should stop the script
and shouldn't further run.
(From OE-Core rev: 651ccb3b031d9ccb8331505a51171372002230d9)
Signed-off-by: Dexuan Cui <dexuan.cui@intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
2011-08-02 06:08:32 +00:00
return 1
2010-11-24 22:25:28 +00:00
fi
2007-05-16 13:48:29 +00:00
2015-02-23 17:00:42 +00:00
if [ -z "$OE_SKIP_SDK_CHECK" -a ! -z "$OECORE_SDK_VERSION" ]; then
2012-10-02 13:08:13 +00:00
echo >&2 "Error: The OE SDK/ADT was detected as already being present in this shell environment. Please use a clean shell when sourcing this environment script."
return 1
fi
2013-06-07 17:16:41 +00:00
# Make sure we're not using python v3.x. This check can't go into
# sanity.bbclass because bitbake's source code doesn't even pass
# parsing stage when used with python v3, so we catch it here so we
# can offer a meaningful error message.
py_v3_check=`/usr/bin/env python --version 2>&1 | grep "Python 3"`
if [ "$py_v3_check" != "" ]; then
2013-06-17 15:38:24 +00:00
echo >&2 "Bitbake is not compatible with python v3"
echo >&2 "Please set up python v2 as your default python interpreter"
2013-06-17 09:40:15 +00:00
return 1
2013-06-07 17:16:41 +00:00
fi
# Similarly, we now have code that doesn't parse correctly with older
# versions of Python, and rather than fixing that and being eternally
# vigilant for any other new feature use, just check the version here.
2013-06-07 17:19:13 +00:00
py_v26_check=`python -c 'import sys; print sys.version_info >= (2,7,3)'`
2013-06-07 17:16:41 +00:00
if [ "$py_v26_check" != "True" ]; then
2013-06-17 15:38:24 +00:00
echo >&2 "BitBake requires Python 2.7.3 or later"
2013-06-17 09:40:15 +00:00
return 1
2013-06-07 17:16:41 +00:00
fi
2008-04-29 17:12:25 +00:00
if [ "x$BDIR" = "x" ]; then
2010-11-28 13:11:57 +00:00
if [ "x$1" = "x" ]; then
2010-07-21 13:55:39 +00:00
BDIR="build"
2010-11-28 13:11:57 +00:00
else
2011-08-04 06:53:20 +00:00
BDIR="$1"
if [ "$BDIR" = "/" ]; then
echo >&2 "Error: / is not supported as a build directory."
return 1
fi
# Remove any possible trailing slashes. This is used to work around
# buggy readlink in Ubuntu 10.04 that doesn't ignore trailing slashes
# and hence "readlink -f new_dir_to_be_created/" returns empty.
BDIR=`echo $BDIR | sed -re 's|/+$||'`
BDIR=`readlink -f "$BDIR"`
if [ -z "$BDIR" ]; then
PARENTDIR=`dirname "$1"`
echo >&2 "Error: the directory $PARENTDIR does not exist?"
oe-init-build-env, scripts/oe-buildenv-internal: add error detecting for $BDIR
[YOCTO #671]
"readlink -f" in Ubuntu 10.04 is buggy: it doesn't ignore a trailing / (e.g.,
"readlink -f /tmp/non-existent-dir/" returns nothing, but according to
http://www.gnu.org/s/coreutils/manual/coreutils.pdf it should do that --
hence we get bug 671. It seems Ubuntu 10.10 or even later Ubuntu 11.04,
and other Linux distributions(e.g., Open Suse 11.4) haven't such an issue.
So I think we should detect this and ask Ubuntu 10.04 users to avoid supply
a path with trailing slash here.
Moreever, I also add the detection of non-existent path, e.g.,
source oe-init-build-env /non-existent-dir/build
can be detected and we'll print an error msg.
And, if we get errors in oe-buildenv-internal, we should stop the script
and shouldn't further run.
(From OE-Core rev: 651ccb3b031d9ccb8331505a51171372002230d9)
Signed-off-by: Dexuan Cui <dexuan.cui@intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
2011-08-02 06:08:32 +00:00
return 1
fi
2010-11-28 13:11:57 +00:00
fi
2012-05-12 07:41:44 +00:00
if [ "x$2" != "x" ]; then
BITBAKEDIR="$2"
fi
2010-07-21 13:55:39 +00:00
fi
2010-11-25 00:06:04 +00:00
if expr "$BDIR" : '/.*' > /dev/null ; then
2010-07-21 13:55:39 +00:00
BUILDDIR="$BDIR"
else
BUILDDIR="`pwd`/$BDIR"
2007-07-17 13:29:36 +00:00
fi
2008-10-28 10:01:03 +00:00
unset BDIR
2010-07-21 13:55:39 +00:00
2012-05-12 07:41:44 +00:00
if [ "x$BITBAKEDIR" = "x" ]; then
2012-05-09 16:44:23 +00:00
BITBAKEDIR="$OEROOT/bitbake$BBEXTRA/"
fi
2008-10-28 10:01:03 +00:00
2008-11-06 15:21:36 +00:00
BITBAKEDIR=`readlink -f "$BITBAKEDIR"`
2007-07-17 13:26:55 +00:00
BUILDDIR=`readlink -f "$BUILDDIR"`
2006-11-23 12:15:17 +00:00
2010-11-24 22:25:28 +00:00
if ! (test -d "$BITBAKEDIR"); then
2011-05-18 11:33:27 +00:00
echo >&2 "Error: The bitbake directory ($BITBAKEDIR) does not exist! Please ensure a copy of bitbake exists at this location"
oe-init-build-env, scripts/oe-buildenv-internal: add error detecting for $BDIR
[YOCTO #671]
"readlink -f" in Ubuntu 10.04 is buggy: it doesn't ignore a trailing / (e.g.,
"readlink -f /tmp/non-existent-dir/" returns nothing, but according to
http://www.gnu.org/s/coreutils/manual/coreutils.pdf it should do that --
hence we get bug 671. It seems Ubuntu 10.10 or even later Ubuntu 11.04,
and other Linux distributions(e.g., Open Suse 11.4) haven't such an issue.
So I think we should detect this and ask Ubuntu 10.04 users to avoid supply
a path with trailing slash here.
Moreever, I also add the detection of non-existent path, e.g.,
source oe-init-build-env /non-existent-dir/build
can be detected and we'll print an error msg.
And, if we get errors in oe-buildenv-internal, we should stop the script
and shouldn't further run.
(From OE-Core rev: 651ccb3b031d9ccb8331505a51171372002230d9)
Signed-off-by: Dexuan Cui <dexuan.cui@intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
2011-08-02 06:08:32 +00:00
return 1
2006-11-23 12:15:17 +00:00
fi
2013-04-09 10:24:13 +00:00
# Make sure our paths are at the beginning of $PATH
NEWPATHS="${OEROOT}/scripts:$BITBAKEDIR/bin:"
PATH=$NEWPATHS$(echo $PATH | sed -e "s|:$NEWPATHS|:|g" -e "s|^$NEWPATHS||")
2013-04-05 16:59:45 +00:00
unset BITBAKEDIR NEWPATHS
2010-05-12 14:43:51 +00:00
2011-04-20 15:44:10 +00:00
# Used by the runqemu script
2010-11-28 12:41:09 +00:00
export BUILDDIR
2010-11-28 13:11:57 +00:00
export PATH
2013-01-29 13:16:28 +00:00
export BB_ENV_EXTRAWHITE="MACHINE DISTRO TCMODE TCLIBC HTTP_PROXY http_proxy \
HTTPS_PROXY https_proxy FTP_PROXY ftp_proxy FTPS_PROXY ftps_proxy ALL_PROXY \
all_proxy NO_PROXY no_proxy SSH_AGENT_PID SSH_AUTH_SOCK BB_SRCREV_POLICY \
SDKMACHINE BB_NUMBER_THREADS BB_NO_NETWORK PARALLEL_MAKE GIT_PROXY_COMMAND \
SOCKS5_PASSWD SOCKS5_USER SCREENDIR STAMPS_DIR"