Skip to content

Latest commit

 

History

History
190 lines (156 loc) · 7.98 KB

building.md

File metadata and controls

190 lines (156 loc) · 7.98 KB

Building C-Kermit for Windows from Source

Building C-Kermit for Windows is easy! All you need is a compiler for Windows (Visual C++ 2019 Community Edition recommended). The compiler you choose will determine what features are available and the minimum version of windows your build of CKW will support. You can use the linked table to help choose the compiler that best meets your needs if you're looking to run on versions of Windows older than XP or CPU architectures other than x86 and ARM.

If you wish to also build the Dialer (entirely optional), you'll need ideally a copy of Visual C++ 6.0 SP6. OpenWatcom 1.9 is also supported but due to a lack of support for CTRL3D32 in that compiler the resulting application will look like something from Windows 3.1.

If you're using MinGW, see Building with MinGW - the content below only applies to Visual C++ and OpenWatcom.

Build Environment

Firstly put the source code somewhere convenient. Where ever you put it, you need to edit setenv.bat in the root of the folder to point to your source code location. Uncomment the line REM set root=C:\src near the top of the file and set the value to where your source code lives, for example set root=C:\dev\ckwin, then save the file.

Prepare optional dependencies

If you want to build with SSH support you must first build libssh and all of its dependencies.

The easiest and quickest way to do this is to use vcpkg:

vcpkg install libssh

You'll then need to edit setenv.bat again and, under the Optional Dependencies heading, you'll need to uncomment the vcpkg_installed variable and set it to the location where you installed vcpkg so the C-Kermit for Windows build process can find libssh:

REM If you've installed these dependencies using vcpkg, set the following
REM to the vcpkg installed directory (where the include, lib and bin
REM subdirectories are) and ignore the rest.
set vcpkg_installed=C:\vcpkg\installed\x86-windows

If you'd rather build it all yourself, see Optional Dependencies for instructions. You don't need to edit setenv.bat any further for this if you're using the same versions of the optional dependencies.

Prepare OpenZinc (optional)

The Dialer is an entirely optional component of C-Kermit for Windows. To build it you'll need to grab a copy of OpenZinc 1.0 from the OpenZinc Website. The full package is the one you need - "OpenZinc Engine, DOS, all Windows, OS/2, Unicode (zip)". This includes source and binaries for a selection of compilers.

Unzip the OpenZinc distribution to the zinc subdirectory directly under the source root so that the following files exist in the following locations relative to each other:

\setenv.bat
\mkzinc.bat
\kermit\k95\ckoker.mak
\zinc\copymak.bat

If you're building with OpenWatcom, this is all that should be required - when you run setenv.bat it will detect the presence of OpenZinc and add it to the build environment so that you can build the Dialer. You can skip ahead to the build step

Building OpenZinc for Visual C++

If you're using Visual C++ you've got to rebuild OpenZinc as the default build configuration included in the OpenZinc distribution is unsuitable (linked against the wrong C runtime). If you've got a supported version of Visual C++ this process should be pretty painless.

To start with, open \zinc\SOURCE\UI_ENV.HPP in your preferred editor and uncomment line 40:

#define ZIL_MSWINDOWS_CTL3D   // Use CTL3DV2.DLL (3D look). For Windows only. 

This will enable 3D Windows 95-style widgets (or the native widgets on XP and newer). This is only necessary for Visual C++ older than 2010.

Next run \setenv.bat. This should detect your compiler, the presence of OpenZinc and the fact you don't have a suitable build of it for your compiler available. You'll get a message along the lines of:

OpenZinc is required for building the dialer. You can build it by extracting
the OpenZinc distribution to C:\dev\ckw\zinc and running
C:\dev\ckw\mkzinc.bat

As instructed, just run mkzinc.bat to build OpenZinc. On a modern PC it doesn't take very long.

Build C-Kermit for Windows

  1. Open a console and change directory to where the source code is located
  2. Setup the Visual C++ or OpenWatcom build environment by running the appropriate batch file for your compiler. Some examples are:
REM Visual C++ 2008:
C:\Program Files\Microsoft Visual Studio 8\VC\bin\vcvars32.bat

REM Visual C++ 2019:
"C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Auxiliary\Build\vcvarsall.bat" x64_x86 -vcvars_ver=14.2

REM Visual C++ 2022, 64bit:
"C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Auxiliary\Build\vcvarsall.bat" x64 -vcvars_ver=14.3

REM OpenWatcom:
C:\watcom\owsetenv.bat
  1. Setup the C-Kermit build environment by running setenv.bat
  2. CD into kermit\p95
  3. run mknt.bat to build the X/Y/Z Modem library
  4. CD into ..\k95
  5. run mknt.bat to build the console version and some related bits
  6. run mkg.bat to build the GUI version (k95g.exe)
  7. run mkdist.bat to collect everything you built plus any redistributable dependencies into kermit\k95\dist

Done! Depending on the Visual C++ version you're using you may need to also distribute the Visual C++ runtime with CKW. If you built with OpenWatcom the runtime libraries should have already been copied there for you but if they weren't you'll need to grab clbr19.dll mt719.dll plbr19.dll from the watcom binnt subdirectory.

Build the Dialer (optional)

To build the dialer, run setenv.bat as you normally would for building C-Kermit, then:

cd kermit\dialer
mk.bat
mkdist.bat

This should leave you with the directory kermit\dialer\dist containing the following files:

File Description
COPYING.LESSOR.txt LGPL License text
dialer.dat Zinc data file containing all the dialer UI bits
k95dial.exe The C-Kermit for Windows Dialer
k95dial.exe.manifest Makes the dialer fit in very slightly better on modern windows
p_direct.znc ?
p_servic.znc ?

All files are required for the dialer to work normally.

Build k95cinit.exe (very optional)

Historically Kermit 95 was, since v1.1.10, distributed with a utility called k95cinit.exe. This tool is only required to correct an issue relating to COM port devices on Windows 95 versions prior to OSR2 described here.

It's pretty unlikely anyone will ever run into the issue this tool solves in the 2020s so building it is highly optional - C-Kermit for Windows will work just fine on modern systems without it.

If you'd like to build this utility anyway, Visual C++ 1.5 is required along with OpenZinc 1.0.

To build it, open a command prompt and run something like the following from the root of your C-Kermit source directory (eg, C:\src):

C:\src> C:\msvc\bin\msvcvars.bat
C:\src> setenv.bat
OpenZinc found!

Your compiler is: Visual C++ 1.0 (16-bit)
This compiler is only supported for building the k95cinit.exe utility.
You can build that now by running mk.bat
C:\src\kermit\dialer\init> mk.bat

The CKW setenv.bat script will detect your environment is set up for the 16bit Visual C++ 1.x compiler (due to running msvcvars.bat) and will configure the environment specially for building k95cinit.exe. All you have to do from there is run mk.bat to do the build, and optionally mkdist.bat to copy all the required files to \kermit\dialer\dist

If you don't have OpenZinc installed you may see a different message instructing you to build OpenZinc first - this will leave the current directory unchanged.