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.
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.
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.
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
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.
- Open a console and change directory to where the source code is located
- 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
- Setup the C-Kermit build environment by running
setenv.bat
- CD into
kermit\p95
- run
mknt.bat
to build the X/Y/Z Modem library - CD into
..\k95
- run
mknt.bat
to build the console version and some related bits - run
mkg.bat
to build the GUI version (k95g.exe) - run
mkdist.bat
to collect everything you built plus any redistributable dependencies intokermit\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.
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.
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.