Files
bacnet_stack/ports/win32
Kari Argillander 0177c59f4a Use pre-commit and editorconfig (#753)
* Add editorconfig and pre-commit config

Editorconfig is widly used and supported file. It says basic things how
files should be formatted.

pre-commit is tool which can automatically check some basic checks like
code formatting everytime someone makes commit. This can also be used in
CI to run these things. Then it is very easy to do same things locally
as in CI. This also makes easy to select clang-format version so
everyone is using same one.

* clang-format: Ignore folders where are external code

We should not format external code. Add clang-format files to exclude
those. We should move external code always to example external/ folder
so we can exclude those more easily.

* clang-format: Remove custom zephyr/.clang-gormat

This clang-format file where introduces before our root clang-format. It
does not make sense anymore as we have root clang-format. Removing this
will unifie formatting in whole repo.

* clang-format: Add couple new rules

Add couple new formatting rules.

Always align const to left side. We did have only one place where it was
right side so this make sense as it is already rule for us.

I choose also insertbraces becuase when I run this I notice that we have
lot of multiline code without braces. So very error prone places. This
will take error possibility away. Repo also always use braces even with
single line statments so this does not matter much.

* ci: Add pre-commit validation

Validate pre-commit in CI.

* format: Convert spaces to tabs in Makefiles

Makefile normally use tabs. We enforce that with editorconfig. Fix
couple places where spaces where still in use.

---------

Co-authored-by: Kari Argillander <kari.argillander@fidelix.com>
2024-08-28 17:04:00 -05:00
..
2024-08-12 15:33:02 -05:00
2024-08-12 15:33:02 -05:00
2019-10-20 13:46:21 -05:00

Win32 ports for BACnet

This directory contains a demo program that compiles with a Win32 compiler. It was tested with the free MinGW32 MSYS2 GCC compiler and the (free) Microsoft Visual Studio Community Edition

Building with Makefile under MinGW32

Note: Building for 64-bit with MinGW64 requires extra runtimes, whereas building for 32-bit as Win32 doesn't require any other files for the EXE to work in any version of Windows.

  • MSYS2 installation is (from powershell):

    c:> winget install --id=MSYS2.MSYS2 -e

  • Start MSYS shell, and install MinGW32.

    $ pacman -Syu mingw-w64-i686-toolchain

  • Edit ~/.bashrc file and add:

    alias make=mingw32-make.exe

  • Exit MSYS.

  • Start MSYS profile for MinGW32.

  • Verify MSYS profile:

    $ uname

    MINGW32_NT-10.0-19045

  • Verify GCC is targeting i686:

    $ gcc -dumpmachine

    i686-w64-mingw32

  • Verify make is built for Windows32:

    make --version

    Built for Windows32

Building and running with Microsoft Visual Studio

  • Obtain the (free) Microsoft Visual Studio Community Edition, or use your professional version. Currently tested to MSVC 2022
  • Open solution file ports/win32/Microsoft Visual Studio/bacnet-stack.sln
  • Set startup project to be the desired application project, e.g. "server"
  • In the active project properties, debugging, set command line to desired DeviceID
  • In active project properties, debugging, set environment variables as appropriate, e.g. BACNET_IFACE=10.59.2.1 BACNET_IP_PORT=53004
  • Compile & run
  • Questions? edward@bac-test.com