Go to file
Calcitem 472b184566
qt: Fix build warning 'QFlags<Qt::MouseButton>::QFlags'
Use default constructor instead.
2021-10-24 19:42:43 +08:00
.github/workflows build: Support Flutter 2.5.3 2021-10-16 12:06:04 +08:00
ci ci: Add run-win32-qt-build.bat 2019-09-05 23:46:08 +08:00
fastlane/metadata/android Sanmill v1.1.38 (2196) 2021-10-05 00:33:27 +08:00
include win32: Remove disabling warning 4996 2021-10-24 19:40:25 +08:00
resources icon: Replace icons 2021-02-14 16:49:37 +08:00
src qt: Fix build warning 'QFlags<Qt::MouseButton>::QFlags' 2021-10-24 19:42:43 +08:00
tests sh: Adapt multi-platforms 2021-07-11 19:55:46 +08:00
.gitignore auto format on save for vsCode 2021-10-08 19:53:01 +02:00
AUTHORS authors: Add Nikolas Rimikis to the authors list 2021-10-11 02:16:04 +08:00
Copying.txt license: Change Licence to GPL 3.0 2019-11-03 13:00:45 +08:00
MillGame.ico icon: Replace icons 2021-02-14 16:49:37 +08:00
Readme.md Readme.txt: Correct alt to "Get it on CafeBazaar" 2021-07-11 19:55:55 +08:00
appveyor.yml msvc: Upgrade to Qt 5.15.2 2021-10-23 11:29:28 +08:00
clean.sh sh: Adapt multi-platforms 2021-07-11 19:55:46 +08:00
cov.sh Add cov.sh 2021-08-14 14:04:59 +08:00
deploy.sh deploy.sh: Do not commit and only push 2020-12-21 23:51:46 +08:00
flutter-init.sh Replace third party notices page to oss license page 2021-06-25 01:54:01 +08:00
flutter-windows-init.sh windows: Enable windows desktop in flutter-windows-init.sh 2021-10-23 14:16:00 +08:00
gamewindow.qrc qt: Remove blank line of gamewindow.qrc 2021-06-18 23:59:02 +08:00
gamewindow.ui settings: Add Algorithm settings 2021-09-20 01:06:50 +08:00
millgame-qt_zh_CN.ts rule: Add 60 option to N-move rule 2021-10-04 17:57:22 +08:00
millgame.pro config: Rename MOBILE_APP_UI to QT_MOBILE_APP_UI 2021-07-31 12:16:10 +08:00
millgame.rc Sanmill v1.1.38 (2196) 2021-10-05 00:33:27 +08:00
millgame.sln msvc: Upgrade to Qt 5.15.2 2021-10-23 11:29:28 +08:00
millgame.vcxproj msvc: Upgrade to Qt 5.15.2 2021-10-23 11:29:28 +08:00
millgame.vcxproj.filters msvc: Fix Win32 build error 2021-01-24 12:07:34 +08:00
programr.md Change N-move rule default value from 50 to 100 2021-06-20 10:57:21 +08:00
rcc.sh chmod +x *.sh 2021-05-29 04:17:02 +08:00
release.sh Add fa-IR resources to fastlane and android res 2021-08-08 01:31:43 +08:00
version.sh macos: Fix version.sh and release.sh 2021-07-11 23:59:39 +08:00

Readme.md

Overview

YouTube

Get it on GitHub Get it on F-Droid Get it on Google Play Get it on CafeBazaar

Build Status Codacy Badge

Sanmill is a free, powerful UCI-like N men's morris program with CUI, Flutter GUI and Qt GUI.

Nine men's morris is a strategy board game for two players dating at least to the Roman Empire. The game is also known as nine-man morris, mill, mills, the mill game, merels, merrills, merelles, marelles, morelles, and ninepenny marl in English.

image

Files

This distribution of Sanmill consists of the following files:

  • Readme.md, the file you are currently reading.

  • Copying.txt, a text file containing the GNU General Public License version 3.

  • src, a subdirectory containing the full source code, including a Makefile that can be used to compile Sanmill CUI on Unix-like systems.

  • src/ui/flutter_app, a subdirectory containing a Flutter frontend.

  • src/ui/qt, a subdirectory containing a Qt frontend.

How to Build

CUI

Sanmill CUI has support for 32 or 64-bit CPUs, certain hardware instructions, big-endian machines such as Power PC, and other platforms.

On Unix-like systems, it should be easy to compile Sanmill directly from the source code with the included Makefile in the folder src. In general it is recommended to run make help to see a list of make targets with corresponding descriptions.

cd src
make help
make build ARCH=x86-64-modern

When reporting an issue or a bug, please tell us which version and compiler you used to create your executable. These information can be found by typing the following commands in a console:

./sanmill compiler

Qt Application

If you have started using Ubuntu or any Ubuntu-based Linux distribution, you must install Qt by running the following command as root:

sudo apt-get install qt5-default qtmultimedia5-dev qtcreator

Use Qt Creator to open millgame.pro , or use Visual Studio to open millgame.sln to build Qt Application.

Flutter App

Run ./flutter-init.sh , copy src/ui/flutter_app/android/key.properties.example to src/ui/flutter_app/android/key.properties, modify it, and then use Android Studio or Visual Studio Code to open src/ui/flutter_app to build Flutter App.

Understanding the code base and participating in the project

Sanmill's improvement over the last couple of years has been a great community effort. There are a few ways to help contribute to its growth.

Improving the code

If you want to help improve the code, there are several valuable resources:

  • In this wiki, many techniques used in Sanmill are explained with a lot of background information.

  • The latest source can always be found on GitHub.

  • Discussions about Sanmill take place in the Discussions.

Terms of use

Sanmill is free, and distributed under the GNU General Public License version 3 (GPL v3). Essentially, this means you are free to do almost exactly what you want with the program, including distributing it among your friends, making it available for download from your website, selling it (either by itself or as part of some bigger software package), or using it as the starting point for a software project of your own.

The only real limitation is that whenever you distribute Sanmill in some way, you must always include the full source code, or a pointer to where the source code can be found. If you make any changes to the source code, these changes must also be made available under the GPL.

For full details, read the copy of the GPL v3 found in the file named Copying.txt.