Contents

Installation on Windows

Introduction

The sourceforge downloads page contains a Windows “msi” installer file for 64-bit Windows systems. Installing this will create a directory C:\objecticon\ containing a binary distribution.

Uninstalling and upgrading

To uninstall, just go to the Windows 10 settings dialog, select “Apps & features”, and find the entry for “objecticon”. Click on it and press “Uninstall”. This will remove the C:\objecticon\ directory.

It is not necessary to remove an old version before upgrading to a newer one; this is done automatically.

The version number of the installed package is formed from the subversion version number. For example subversion version 12345 would be package version “1.23.45.0”.

Path setup

The C:\objecticon directory contains a batch file, paths.bat which can be run to setup the various environment variables needed by the translator. It also adds C:\objecticon\bin to the PATH.

It is not necessary to set any path or other environment variables before running a translated Object Icon program, because the path to the runtime interperter oix is embedded into the executable output by the translator.

Console I/O

When outputting UTF-8 to the console (for example when writing a ucs string), the console’s code page should be set with the following command :-

chcp 65001

Unfortunately I haven’t found a way to read UTF-8 input from the console. Unicode characters appear as null (ascii 0) characters when read.

Line endings

The string literal escape sequence “\N” can be used to produce a platform-independent line ending. On Windows, this sequence expands to “\r\n”, and on other platforms to just “\n”.

Launching programs from the desktop

oix is built as a Windows console application. This means that Windows will create a console window for oix unless it is started from an existing console. This can be annoying; starting an Object Icon program via a desktop icon will open an unwanted console window. However, this behaviour can be mitigated by setting the environment variable OI_HIDE_CONSOLE to 1, before starting a particular program. This will make oix hide the console window when it starts up. Thus hidden, the console window will still exist, but it won’t appear in the taskbar, the “alt-tab” switcher, and so on.

Obviously it is not desirable to do this in the general case, so OI_HIDE_CONSOLE should not be set outside of an individual batch file or command line to launch a program from the desktop. A batch file might look like this :-

set OI_HIDE_CONSOLE=1
someprog.exe

This batch file sets the variable, and runs the (Object Icon) program someprog.exe, which in turn runs oix. The console window will then be hidden, and will thus appear to the user only instantaneously.

A call command to another batch file, to set up variables such as OI_FONT, OI_FONT_SIZE and so on could also be made before someprog is started.

An alternative to using a batch file is to create a shortcut to the desired Object Icon program, and place that on the desktop. Then, edit that shortcut and change the “Target” field to something like :-

C:\Windows\System32\cmd.exe /c "set ^"OI_HIDE_CONSOLE=1^" && <program>"

where <program> is original value of “Target”; ie the path to the program to run. Note that the use of quotes, and escaped inner quotes (^“) is important. Without the latter, the value of OI_HIDE_CONSOLE would include a space after the “1”, and would thus be invalid. Also, <program> would need to be surrounded by escaped quotes if it contained spaces.

Like the batch file, a call command to set variables could be inserted before the program is started.

It is tempting to configure the shortcut to use a minimized window (the “Run” field). However, this gives poor results and leads to the Object Icon program’s window starting minimized itself, behind other windows, or without the keyboard focus.

Unicode support

Wherever possible, the wide-character versions of the Win32 API are used, with conversions to and from UTF-8 (used internally by the ucs type).

ieval

ieval should work acceptably in the Windows console, but the program’s built-in line editing will be disabled. However, the console’s own line editing can of course be used instead. Alternatively, the graphics version of ieval (option -g) can be used.

OpenSSL

The binary distribution includes the ssl library (in lib/native). This DLL is statically linked to the OpenSSL libraries.

To be useful, OpenSSL needs to have access to a set of root authority certificates. This enables the identity of remote hosts to be verified. A helpful page containing up-to-date certificates extracted from Mozilla is https://curl.haxx.se/docs/caextract.html. The certificates are contained in a single “.pem” file. After saving this file, OpenSSL can be directed to use it by setting the environment variable “SSL_CERT_FILE” to the location of the file.

Compilation

This section describes how to compile Object Icon on Windows (32 and 64 bit).

Cygwin

Cygwin must be installed. It is used to provide make and some other shell utilities. gcc is not required however, since the Microsoft Visual C/C++ compiler is used. The compiled executables don’t rely on Cygwin in any way, and can be used from a Windows command prompt window if desired (a paths.bat file is provided to set the usual environment variables).

Microsoft Visual C++ compiler

The C/C++ compiler of Visual Studio 2015 or later must be used. It is not necessary to install Visual Studio itself; rather just the build tools alone are sufficient. These are a free download :-

https://visualstudio.microsoft.com/visual-cpp-build-tools/

The compiler executable, cl, must be on the cygwin shell’s PATH. Both 32 and 64 bit versions of the compiler are supported. To see which version is on the path, just type cl at the bash prompt. For 32 bits the output might be :-

Microsoft (R) C/C++ Optimizing Compiler Version 19.00.23026 for x86
Copyright (C) Microsoft Corporation.  All rights reserved.

whilst for the 64 bit version :-

Microsoft (R) C/C++ Optimizing Compiler Version 19.00.23026 for x64
Copyright (C) Microsoft Corporation.  All rights reserved.

Apart from PATH, the enviroment variables INCLUDE, LIB and LIBPATH need to be set correctly for the compiler to work from the command line. To find the correct settings, open a command prompt window, and run the vcvarsall.bat batch file, as described in the following page :-

https://msdn.microsoft.com/en-us/library/x4d2c09s.aspx

After running the batch file, the correct environment variable settings can be noted and placed in .bash_profile. Example settings are, for 32 bits :-

PATH=/cygdrive/c/Program\ Files\ \(x86\)/Microsoft\ Visual\ Studio\ 14.0/VC/bin:/cygdrive/c/Program\ Files\ \(x86\)/Microsoft\ Visual\ Studio\ 14.0/Common7/IDE:/cygdrive/c/Program\ Files/Debugging\ Tools\ for\ Windows\ \(x64\):$PATH
export INCLUDE='C:\Program Files (x86)\Microsoft Visual Studio 14.0\VC\INCLUDE;C:\Program Files (x86)\Microsoft Visual Studio 14.0\VC\ATLMFC\INCLUDE;C:\Program Files (x86)\Windows Kits\10\include\10.0.10150.0\ucrt;C:\Program Files (x86)\Windows Kits\NETFXSDK\4.6\include\um;C:\Program Files (x86)\Windows Kits\8.1\include\shared;C:\Program Files (x86)\Windows Kits\8.1\include\um;C:\Program Files (x86)\Windows Kits\8.1\include\winrt;'
export LIB='C:\Program Files (x86)\Microsoft Visual Studio 14.0\VC\LIB;C:\Program Files (x86)\Microsoft Visual Studio 14.0\VC\ATLMFC\LIB;C:\Program Files (x86)\Windows Kits\10\lib\10.0.10150.0\ucrt\x86;C:\Program Files (x86)\Windows Kits\NETFXSDK\4.6\lib\um\x86;C:\Program Files (x86)\Windows Kits\8.1\lib\winv6.3\um\x86;'
export LIBPATH='C:\Windows\Microsoft.NET\Framework\v4.0.30319;C:\Program Files (x86)\Microsoft Visual Studio 14.0\VC\LIB;C:\Program Files (x86)\Microsoft Visual Studio 14.0\VC\ATLMFC\LIB;References\CommonConfiguration\Neutral;\Microsoft.VCLibs\14.0\References\CommonConfiguration\neutral;'

and for 64 bits :-

PATH=/cygdrive/c/Program\ Files\ \(x86\)/Microsoft\ Visual\ Studio\ 14.0/VC/bin/amd64:/cygdrive/c/Program\ Files\ \(x86\)/Microsoft\ Visual\ Studio\ 14.0/Common7/IDE:/cygdrive/c/Program\ Files/Debugging\ Tools\ for\ Windows\ \(x64\):$PATH
export INCLUDE='C:\Program Files (x86)\Microsoft Visual Studio 14.0\VC\INCLUDE;C:\Program Files (x86)\Microsoft Visual Studio 14.0\VC\ATLMFC\INCLUDE;C:\Program Files (x86)\Windows Kits\10\include\10.0.10150.0\ucrt;C:\Program Files (x86)\Windows Kits\NETFXSDK\4.6\include\um;C:\Program Files (x86)\Windows Kits\8.1\include\shared;C:\Program Files (x86)\Windows Kits\8.1\include\um;C:\Program Files (x86)\Windows Kits\8.1\include\winrt;'
export LIB='C:\Program Files (x86)\Microsoft Visual Studio 14.0\VC\LIB\amd64;C:\Program Files (x86)\Microsoft Visual Studio 14.0\VC\ATLMFC\LIB\amd64;C:\Program Files (x86)\Windows Kits\10\lib\10.0.10150.0\ucrt\x64;C:\Program Files (x86)\Windows Kits\NETFXSDK\4.6\lib\um\x64;C:\Program Files (x86)\Windows Kits\8.1\lib\winv6.3\um\x64;'
export LIBPATH='C:\Windows\Microsoft.NET\Framework64\v4.0.30319;C:\Program Files (x86)\Microsoft Visual Studio 14.0\VC\LIB\amd64;C:\Program Files (x86)\Microsoft Visual Studio 14.0\VC\ATLMFC\LIB\amd64;References\CommonConfiguration\Neutral;\Microsoft.VCLibs\14.0\References\CommonConfiguration\neutral;'

Compiling from the subversion source repository

Use the following command to checkout a read-only copy of the source code :-

svn co svn://svn.code.sf.net/p/objecticon/code/trunk objecticon

This will create a directory objecticon under the present directory (you can change the last parameter to create a different directory name if you want).

Compiling from a tar.gz file

Extract the source code from the .tar.gz file with a command like

tar xfz objecticon-1234.tar.gz

This will create a directory objecticon-1234 under the current directory. The number is the subversion version number from which the .tar.gz was built, and will of course be different. You can rename this directory if you like, but it must not be renamed (or moved) after configuration and compilation.

Third-party libraries

Microsoft’s vcpkg (see https://github.com/microsoft/vcpkg) can be used to provide the external libraries for zlib, OpenSSL and MySQL. zlib is just used to provide the -Z option to oit, whilst OpenSSL and MySQL provide the ssl and mysql libraries (in lib/native).

After installation of vcpkg, use one or more of the following commands to install the desired libraries (for a 64-bit build) :-

vcpkg install openssl:x64-windows-static
vcpkg install libmysql:x64-windows-static
vcpkg install zlib:x64-windows-static

The shared library versions can be installed instead (the same commands, but without the -static ending). In this case, the appropriate vcpkg bin directory must be on the executable PATH variable, so that the third-party DLLs can be located as needed.

Configuration

After ensuring that the cl compiler is available, change to the new directory and run the following command at the bash prompt :-

./configure-win32 [OPTIONS]

This is the equivalent of running the ./configure script on a Unix system. Afterwards, make can be run to compile everything, and make test will run the tests. The script accepts the following options :-

Note that the -D option should only be used with the dynamic library versions of the vcpkg libraries; conversely, without -D, only the static versions should be used. Also, -D necessitates the correct PATH setting. The examples below clarify these points.

Examples

Compile with a statically linked runtime, and make use of ssl and zlib libraries :-

./configure-win32 -v "C:\vcpkg\installed\x64-windows-static" -sz

The resulting oix.exe is about 2.2MB.

Like the above, but with “release” settings; this is what I use to build the msi file :-

./configure-win32 -v "C:\vcpkg\installed\x64-windows-static" -rsz

oix.exe is about 870KB.

Compile with dynamic linking to the runtime, again using ssl and zlib :-

# PATH must include C:\vcpkg\installed\x64-windows\debug\bin
./configure-win32 -v "C:\vcpkg\installed\x64-windows" -Dsz

oix.exe is about 1MB.

And the same, with release settings (note the slightly different PATH setting) :-

# PATH must include C:\vcpkg\installed\x64-windows\bin
./configure-win32 -v "C:\vcpkg\installed\x64-windows" -Dszr

oix.exe is about 590KB.

Environment variables

Amongst other things, the configure-win32 script creates a paths.sh file, which can be used to set the various Object Icon environment variables from within the cygwin bash shell, and paths.bat which sets the same variables from within the Windows command line.

Contents