2011-05-02 20:12:57 +03:00
|
|
|
This set of scripts is to provide a unix-like build environment on Windows.
|
|
|
|
---------------------------------------------------------------------------
|
|
|
|
|
2011-05-03 14:43:15 +03:00
|
|
|
1. Why do I need it?
|
|
|
|
2. How to install?
|
|
|
|
3. How to use it?
|
|
|
|
3.1. Interactive mode
|
|
|
|
3.2. Batch mode
|
|
|
|
4. Advanced usage
|
|
|
|
5. Limitations of use
|
|
|
|
6. Credits and license
|
|
|
|
|
|
|
|
|
|
|
|
1. Why do I need it?
|
|
|
|
--------------------
|
2011-05-02 20:12:57 +03:00
|
|
|
It allows to use the "Big Hammer", that is, to build whole OpenPilot system
|
|
|
|
with a single command "make all" using the top level Makefile originally
|
|
|
|
written for Linux and Mac only.
|
|
|
|
|
2011-05-03 14:43:15 +03:00
|
|
|
Also any routine task automation could use the same set of scripts and commands
|
|
|
|
on all platforms (Linux, Mac and Windows) if scripts are written in the shell
|
|
|
|
language. It is particularly important for cross-paltform projects like the
|
|
|
|
OpenPilot.
|
2011-05-02 20:12:57 +03:00
|
|
|
|
|
|
|
|
2011-05-03 14:43:15 +03:00
|
|
|
2. How to install?
|
|
|
|
------------------
|
|
|
|
Fortunately, it requires only few small text files since all others components
|
|
|
|
should already be installed on your system as parts of msysGit, QtSDK and
|
|
|
|
CodeSourcery G++ packages required to build the OpenPilot.
|
2011-05-02 20:12:57 +03:00
|
|
|
|
|
|
|
It is expected that you have the following tools installed into the listed
|
|
|
|
locations (but any other locations are fine as well):
|
|
|
|
|
|
|
|
- Python in C:\Python27
|
2011-05-28 11:45:22 +03:00
|
|
|
- QtSDK in C:\Qt\2010.05 or C:\QtSDK (depending on SDK version)
|
2011-05-21 13:14:15 +03:00
|
|
|
- CodeSourcery G++ in %ProgramFiles%\CodeSourcery\Sourcery G++ Lite
|
2011-05-02 21:05:13 +03:00
|
|
|
- msysGit in %ProgramFiles%\Git
|
|
|
|
- Unicode NSIS in %ProgramFiles%\NSIS\Unicode
|
2011-05-28 11:45:22 +03:00
|
|
|
- OpenOCD in C:\OpenOCD\0.4.0\bin (optional)
|
|
|
|
|
|
|
|
The SDL library and headers should be installed into Qt directories to build
|
|
|
|
the GCS. Check the wiki or ground/openpilotgcs/copydata.pro for details.
|
2011-05-02 20:12:57 +03:00
|
|
|
|
|
|
|
Also it is assumed that you have the C:\Program Files\Git\cmd\ directory in
|
2011-05-03 14:43:15 +03:00
|
|
|
the PATH. Usually this is the case for msysGit installation if you have chosen
|
|
|
|
the 2nd option: put only git and gitk in the PATH (it is recommended option).
|
2011-05-02 20:12:57 +03:00
|
|
|
|
2011-05-15 14:54:24 +03:00
|
|
|
Now you need to copy few files to your msysGit installation folders.
|
2011-05-02 20:12:57 +03:00
|
|
|
Assuming that you installed the msysGit into C:\Program Files\Git\,
|
|
|
|
you have to copy:
|
|
|
|
|
2011-05-15 14:54:24 +03:00
|
|
|
make\winx86\bin\* -> C:\Program Files\Git\bin\
|
|
|
|
make\winx86\cmd\* -> C:\Program Files\Git\cmd\
|
2011-05-02 20:12:57 +03:00
|
|
|
|
2011-05-03 14:43:15 +03:00
|
|
|
If you have msysGit installed into another directory, you need to update paths
|
|
|
|
accordingly. Also if you have tools installed into different directories and
|
|
|
|
they are not in the PATH, then you may want to update paths in the sh.cmd
|
|
|
|
script too (it is self-documented).
|
2011-05-02 20:12:57 +03:00
|
|
|
|
2011-05-21 13:14:15 +03:00
|
|
|
Note for Windows 64-bit users: 64-bit systems use %ProgramFiles(x86)% folder
|
|
|
|
as default for program files instead of %ProgramFiles%. You have to check where
|
|
|
|
your tools are installed and update paths above accordingly.
|
|
|
|
|
2011-05-02 20:12:57 +03:00
|
|
|
|
2011-05-03 14:43:15 +03:00
|
|
|
3. How to use it?
|
|
|
|
-----------------
|
2011-05-02 20:12:57 +03:00
|
|
|
|
2011-05-03 14:43:15 +03:00
|
|
|
3.1. Interactive mode
|
|
|
|
---------------------
|
2011-05-02 20:12:57 +03:00
|
|
|
|
|
|
|
1) Type:
|
|
|
|
|
|
|
|
C:\> sh
|
|
|
|
|
|
|
|
and the bash prompt should appear:
|
|
|
|
|
|
|
|
user@pc /
|
|
|
|
$
|
|
|
|
|
|
|
|
2) Enter your OpenPilot directory:
|
|
|
|
|
|
|
|
user@pc /
|
|
|
|
$ cd D:/Work/OpenPilot/git
|
|
|
|
|
|
|
|
user@pc /d/Work/OpenPilot/git (master)
|
|
|
|
$
|
|
|
|
|
2011-05-03 14:43:15 +03:00
|
|
|
Note the current git branch in parentheses (master), if it exists. The path
|
|
|
|
format is also printed according to MSYS notation. And you have to use forward
|
|
|
|
slashes in paths, not backslashes.
|
2011-05-02 20:12:57 +03:00
|
|
|
|
|
|
|
3) Enter make command with required options and target list:
|
|
|
|
|
|
|
|
user@pc /d/Work/OpenPilot/git (master)
|
|
|
|
$ make all
|
|
|
|
|
2011-05-03 14:43:15 +03:00
|
|
|
The building should be started, and you will have full system including ground
|
|
|
|
software and flight firmware built in the end.
|
2011-05-02 20:12:57 +03:00
|
|
|
|
|
|
|
4) To build parts of the system you can use, for example, such commands:
|
|
|
|
|
|
|
|
user@pc /d/Work/OpenPilot/git (master)
|
2011-05-09 02:56:52 +03:00
|
|
|
$ make -j2 GCS_BUILD_CONF=release gcs coptercontrol
|
2011-05-02 20:12:57 +03:00
|
|
|
|
|
|
|
or to completely remove the build directory:
|
|
|
|
|
|
|
|
user@pc /d/Work/OpenPilot/git (master)
|
|
|
|
$ make all_clean
|
|
|
|
|
|
|
|
|
2011-05-03 14:43:15 +03:00
|
|
|
3.2. Batch mode
|
|
|
|
---------------
|
2011-05-02 20:12:57 +03:00
|
|
|
|
|
|
|
1) Create a shell script file containing all required commands, for instance:
|
|
|
|
|
|
|
|
#!/bin/sh
|
|
|
|
# This is the cc_make_release.sh file used to build CC release software
|
|
|
|
cd D:/Work/OpenPilot/git
|
2011-05-09 02:56:52 +03:00
|
|
|
make -j2 GCS_BUILD_CONF=release gcs coptercontrol
|
2011-05-02 20:12:57 +03:00
|
|
|
echo RC=$?
|
|
|
|
|
|
|
|
2) Run it typing:
|
|
|
|
|
|
|
|
C:\> sh cc_make_release.sh
|
|
|
|
|
|
|
|
3) Of course, a lot of other shell commands can be used in scripts.
|
2011-05-03 14:43:15 +03:00
|
|
|
|
|
|
|
|
|
|
|
4. Advanced usage
|
|
|
|
-----------------
|
|
|
|
|
|
|
|
It is possible to go further and integrate shell scripting into Windows system
|
|
|
|
like any other executables. This allows:
|
|
|
|
|
|
|
|
- double click on any .sh file in the Explorer window to execute it;
|
|
|
|
- type name of .sh file with any arguments on the command line to run script;
|
|
|
|
- omit .sh extension typing names since it is now recognized automatically;
|
|
|
|
- call .sh scripts even from .bat and .cmd files as Windows command;
|
|
|
|
- execute scripts which are in any directory in the PATH;
|
|
|
|
- return and check exit code from .sh scripts to .bat or .cmd batch files.
|
|
|
|
|
|
|
|
In short, you may have quite powerful and cross-platform bash scripting on
|
|
|
|
Windows.
|
|
|
|
|
|
|
|
In order to integrate bash scripting into Windows system you need to:
|
|
|
|
|
|
|
|
- double click on the included shell_script.reg file to register .sh
|
|
|
|
extension in the system. Thus, any click on .sh script will execute it
|
|
|
|
automatically assuming that the sh.cmd is in the PATH;
|
|
|
|
- register .sh extension as an executable file type, so you can omit the
|
|
|
|
.sh typing commands. To do so open "My Computer" properties dialog, choose
|
|
|
|
the "Advanced" tab, "Environment variables", in the "System variables"
|
|
|
|
find the variable called "PATHEXT". It contains the list of "executable"
|
|
|
|
file extensions separated by semicolon. You want to add a ";.SH" to the
|
|
|
|
end of its value. Then click OK to apply.
|
|
|
|
|
|
|
|
Now any .sh script can be run just by typing its name, optionally with
|
|
|
|
parameters.
|
|
|
|
|
|
|
|
As an example, you can create a shell script named make.sh in the cmd/
|
|
|
|
subdirectory of Git installation with the following content:
|
|
|
|
|
|
|
|
exec /bin/make $*
|
|
|
|
|
|
|
|
and then build the OpenPilot software typing
|
|
|
|
|
|
|
|
make all
|
|
|
|
|
|
|
|
directly from Windows command line or from a batch file.
|
|
|
|
|
|
|
|
You also may want to rename or remove "C:\Program Files\Git\etc\motd" file
|
|
|
|
to get rid of git bash welcome message on every script invocation.
|
|
|
|
|
|
|
|
|
|
|
|
5. Limitations of use
|
|
|
|
---------------------
|
|
|
|
|
|
|
|
Currently there may be some problems running scripts which contain spaces in
|
|
|
|
file names or located in directories which contain spaces in full paths.
|
2011-05-09 02:56:52 +03:00
|
|
|
It results in strange "file not found" or other errors.
|
2011-05-03 14:43:15 +03:00
|
|
|
|
|
|
|
It is recommended to avoid using such names with spaces.
|
|
|
|
|
|
|
|
|
|
|
|
6. Credits and license
|
|
|
|
----------------------
|
|
|
|
|
|
|
|
This set of scripts uses the MSYS package included into the msysGit
|
|
|
|
distribution and MinGW make included into the QtSDK package.
|
|
|
|
|
|
|
|
The sh.cmd, shell_script.reg and this README.txt files were written
|
|
|
|
by Oleg Semyonov (os-openpilot-org@os-propo.info) for the OpenPilot
|
|
|
|
project and are licensed under CC-BY-SA terms:
|
|
|
|
|
|
|
|
http://creativecommons.org/licenses/by-sa/3.0/
|
|
|
|
|
|
|
|
Feel free to contact me for additions and improvements.
|
|
|
|
|
|
|
|
Happy bashing!
|