Started working on c++

This commit is contained in:
Lukas Wölfer
2020-03-15 23:56:05 +01:00
parent 8cd39b10c2
commit a6cca47d99
9 changed files with 42 additions and 3796 deletions

View File

@@ -0,0 +1,10 @@
project("solitaire" LANGUAGES CXX)
cmake_minimum_required(VERSION 3.16)
set(CMAKE_MODULE_PATH "${CMAKE_SOURCE_DIR}/cmake")
include( "common" )
add_library(board STATIC lib/board.cpp)
set_property(TARGET board PROPERTY CXX_STANDARD 17)
target_include_directories(board PUBLIC include)

View File

@@ -1,66 +0,0 @@
# This file was automatically generated by SWIG (http://www.swig.org).
# Version 4.0.1
#
# Do not make changes to this file unless you know what you are doing--modify
# the SWIG interface file instead.
from sys import version_info as _swig_python_version_info
if _swig_python_version_info < (2, 7, 0):
raise RuntimeError("Python 2.7 or later required")
# Import the low-level C/C++ module
if __package__ or "." in __name__:
from . import __shenzhen_solitaire
else:
import __shenzhen_solitaire
try:
import builtins as __builtin__
except ImportError:
import __builtin__
def _swig_repr(self):
try:
strthis = "proxy of " + self.this.__repr__()
except __builtin__.Exception:
strthis = ""
return "<%s.%s; %s >" % (self.__class__.__module__, self.__class__.__name__, strthis,)
def _swig_setattr_nondynamic_instance_variable(set):
def set_instance_attr(self, name, value):
if name == "thisown":
self.this.own(value)
elif name == "this":
set(self, name, value)
elif hasattr(self, name) and isinstance(getattr(type(self), name), property):
set(self, name, value)
else:
raise AttributeError("You cannot add instance attributes to %s" % self)
return set_instance_attr
def _swig_setattr_nondynamic_class_variable(set):
def set_class_attr(cls, name, value):
if hasattr(cls, name) and not isinstance(getattr(cls, name), property):
set(cls, name, value)
else:
raise AttributeError("You cannot add class attributes to %s" % cls)
return set_class_attr
def _swig_add_metaclass(metaclass):
"""Class decorator for adding a metaclass to a SWIG wrapped class - a slimmed down version of six.add_metaclass"""
def wrapper(cls):
return metaclass(cls.__name__, cls.__bases__, cls.__dict__.copy())
return wrapper
class _SwigNonDynamicMeta(type):
"""Meta class to enforce nondynamic attributes (no new attributes) for a class"""
__setattr__ = _swig_setattr_nondynamic_class_variable(type.__setattr__)
cvar = __shenzhen_solitaire.cvar

View File

@@ -0,0 +1,27 @@
#include <array>
#include <optional>
namespace solitaire {
class Card {
bool isNormalCard();
bool isSpecialCard();
};
struct BunkerField{
Card card;
bool empty;
bool closed;
};
class Board {
public:
static constexpr int MAX_ROW_SIZE = 13;
static constexpr int MAX_COLUMN_SIZE = 8;
private:
std::array<std::array<Card, MAX_COLUMN_SIZE>, MAX_ROW_SIZE> field;
std::array<BunkerField, 3> bunker;
std::array<std::optional<Card>, 3> goal;
bool flower_gone;
};
} // namespace solitaire

View File

@@ -0,0 +1 @@
#include "board.hpp"

View File

@@ -1 +0,0 @@
int a;

View File

@@ -1,7 +0,0 @@
%module _shenzhen_solitaire
%{
#define SWIG_FILE_WITH_INIT
extern int a;
%}
int a;

File diff suppressed because it is too large Load Diff