Started working on c++
This commit is contained in:
3
.gitmodules
vendored
Normal file
3
.gitmodules
vendored
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
[submodule "shenzhen_solitaire/c++/cmake"]
|
||||||
|
path = shenzhen_solitaire/c++/cmake
|
||||||
|
url = git@github.com:corrodedHash/cmake-framework.git
|
||||||
10
shenzhen_solitaire/c++/CMakeLists.txt
Normal file
10
shenzhen_solitaire/c++/CMakeLists.txt
Normal 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)
|
||||||
@@ -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
|
|
||||||
|
|
||||||
1
shenzhen_solitaire/c++/cmake
Submodule
1
shenzhen_solitaire/c++/cmake
Submodule
Submodule shenzhen_solitaire/c++/cmake added at c888dc5541
27
shenzhen_solitaire/c++/include/board.hpp
Normal file
27
shenzhen_solitaire/c++/include/board.hpp
Normal 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
|
||||||
1
shenzhen_solitaire/c++/lib/board.cpp
Normal file
1
shenzhen_solitaire/c++/lib/board.cpp
Normal file
@@ -0,0 +1 @@
|
|||||||
|
#include "board.hpp"
|
||||||
@@ -1 +0,0 @@
|
|||||||
int a;
|
|
||||||
@@ -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
Reference in New Issue
Block a user