1 # Installing WRF on Cygwin
3 1. Download https://cygwin.com/setup-x86_64.exe
4 2. (Optional) Download https://cygwin.com/setup-x86_64.exe.sig and verify the signature
5 3. Run `setup-x86_64.exe`
6 - Select `Install from Internet`
7 - Pick an installation root (installing directly into `C:\` is not
9 - Pick a directory for a download cache
10 - If installing Cygwin on multiple computers, these files can
11 be re-used, skipping the download step on those computers
12 - `Direct Connection` is nice if it works, but `System Proxy Settings`
13 may fill in useful data from your OS.
14 - Select a mirror near you
15 - Change package view to `Full`
16 - Select for install at least:
17 - gcc-core (OpenMP for smpar)
19 - libnetcdf-fortran-devel
23 - openmpi (MPI for dmpar)
24 - libopenmpi-devel (MPI for dmpar)
25 - libhwloc-devel (MPI for dmpar)
26 - libevent-devel (MPI for dmpar)
27 - libjasper-devel (GRIB)
43 - Accept the packages pulled in as dependencies
44 - Wait for download, install, and postinstall steps. This will
45 take about an hour the first time through
46 - Decide whether you want shortcuts from the Desktop or Start Menu
48 - If you didn't install shortcuts, you can run the `Cygwin.bat`
49 file in the root of the Cygwin install tree
50 5. Follow usual instructions for installing WRF
51 - Download and unpack source
53 - Export variables so WRF can find everything:
54 - `export NETCDF=/usr/ NETCDF4=1 HDF5=/usr`
55 - (Optional) `export JASPER=/usr JASPERLIB=/usr/lib JASPERINC=/usr/include`
56 - (Optional) `export WRFIO_NCD_NO_LARGE_FILE_SUPPORT=0 NETCDF_classic=0`
57 - `./configure`, follow directions
58 - `./compile`, follow directions
62 If the compiler reports problems due to `mpi.mod` or `netcdf.mod`
63 being compiled with a different version of gfortran, subscribe to the
64 [cygwin mailing list](https://cygwin.com/lists.html) and send a
65 message there to remind the maintainer that `openmpi` or
66 `netcdf-fortran` was built with an old version of `gfortran` and to
67 ask them nicely to update it.
69 If the (volunteer) maintainer does not have time, or you want to build
70 this yourself, re-run `setup-x86_64.exe` and check the `Source?` box
71 next to `openmpi` or `libnetcdf-fortran-devel`, install `cygport` and
72 finish the install. Unpack the archives in `/usr/src` (`tar xaf ...`
73 should do the trick), and `cd` into the new directory. There will be
74 a `.cygport` file with the build script. Edit this to add a `.1`
75 after the current release field. Save this file, then run
76 `cygport ${package}.cygport download prep compile test install package`
77 If there are errors, try to fix them, then re-run
78 `cygport ${package}.cygport compile test install package`
79 Once it compiles, you can follow the directions in
80 https://cygwin.com/package-server.html#overlay
81 to set up a local package server and install from that, or you can run
84 for name in /usr/src/${package}-${version}*/${package}-${version}*/dist/**.tar.xz;
89 then re-run setup to make sure everything still works.
90 The first method plays much nicer with other tools.
92 If you feel nice, you can tell the maintainer whether the package
93 compiled, whether the tests passed and what you needed to do to make
94 it do that. The contents of
95 `/usr/src/${package}-${version}*/${package}-${version}*/patch` might