1
0
Fork 0
mirror of https://github.com/zeldaret/oot.git synced 2024-12-29 08:16:11 +00:00
oot/docs/BUILDING_CYGWIN.md
EllipticEllipsis 9b67778a00
Building on Macs (#1086)
* git subrepo pull (merge) tools/ZAPD

subrepo:
  subdir:   "tools/ZAPD"
  merged:   "945e6ca1a"
upstream:
  origin:   "https://github.com/zeldaret/ZAPD.git"
  branch:   "master"
  commit:   "50242eca9"
git-subrepo:
  version:  "0.4.3"
  origin:   "https://github.com/ingydotnet/git-subrepo.git"
  commit:   "2f68596"

* Fix extract_assets.py multithreading

* Update binutils doc a bit

* Remove * import, add multiprocessing option
and way to pass arguments to ZAPD

* Update format.sh to be more platform-independent

* git subrepo pull --force tools/ZAPD

subrepo:
  subdir:   "tools/ZAPD"
  merged:   "fd5a7f434"
upstream:
  origin:   "https://github.com/zeldaret/ZAPD.git"
  branch:   "master"
  commit:   "fd5a7f434"
git-subrepo:
  version:  "0.4.3"
  origin:   "https://github.com/ingydotnet/git-subrepo.git"
  commit:   "2f68596"

* Remove ;

* Update formatting script to not just use 11

* Add Python requirements,
move the Mac stuff in the README into its own doc

* Fix readme link

* Minor format thing

* .

* Move ZAPDArgs into its own function

* Update readme and remove requirements.txt

* Dragorn-inspired rewrite of processZAPDArgs

* git subrepo pull --force tools/ZAPD

subrepo:
  subdir:   "tools/ZAPD"
  merged:   "a0d3f7b68"
upstream:
  origin:   "https://github.com/zeldaret/ZAPD.git"
  branch:   "master"
  commit:   "a0d3f7b68"
git-subrepo:
  version:  "0.4.3"
  origin:   "https://github.com/ingydotnet/git-subrepo.git"
  commit:   "2f68596"

* Fix function definition

* Building docs overhaul

* Add Python packages to Mac and Cygwin

* Heading number

* format format.sh (!)

* Replace "currently"

* Remove Debian

* git subrepo pull (merge) --force tools/ZAPD

subrepo:
  subdir:   "tools/ZAPD"
  merged:   "0ba781304"
upstream:
  origin:   "https://github.com/zeldaret/ZAPD.git"
  branch:   "master"
  commit:   "0ba781304"
git-subrepo:
  version:  "0.4.3"
  origin:   "https://github.com/ingydotnet/git-subrepo.git"
  commit:   "2f68596"
2022-01-16 19:43:07 -05:00

2.1 KiB

Building with Cygwin

N.B. These have not been tested recently, you may find the requirements have changed a bit.

If you want to use Cygwin, you will need to:

1. Install Git Bash and Cygwin

2. Build mips-linux-binutils on Windows using Cygwin

First, you will need to install the following packages using the Cygwin installer:

  • make
  • gcc-g++
  • bison
  • flex
  • texinfo
  • binutils (Make sure to check the "Src?" checkbox since we're interested in the source code. Once the download is finished, you will find it in /usr/src/)

Create destination dir for binutils

sudo mkdir -p /opt/cross

Extract binutils source

cd /usr/src/binutils-[...].src/
tar xjf binutils-[...].tar.bz2

Create and enter build dir

mkdir build-binutils
cd build-binutils

Configure the build

../binutils-gdb/configure --target=mips-linux-gnu --prefix=/opt/cross --disable-gprof --disable-nls --disable-werror --disable-gdb --disable-libdecnumber --disable-readline --disable-sim

Make and install binutils

make -j
sudo make install -j

Add the new binutils binaries to your system PATH:

You can do that by adding PATH=$PATH:/opt/cross/bin to ~/.bashrc and then reloading ~/.bashrc.

Alternatively you can edit the Path variable in Edit the system environment variables>Environment Variables (in which case you will need to relaunch your terminal).

3. Install required Cygwin packages

Once mips-linux-binutils is installed you will need to install the following packages using Cygwin's installer:

  • libiconv
  • dos2unix
  • python3
  • libpng-devel

4. Install required Python packages

To install the Python dependencies simply run in a terminal:

python3 -m pip install colorama

5. Continue with Linux instructions

You should be able to continue from step step 2 of the Linux instructions.

N.B. Before building anything, you will need to run the following commands to fix line endings:

dos2unix fixle.sh
./fixle.sh