X-Git-Url: http://winboard.nl/cgi-bin?a=blobdiff_plain;f=common.h;h=92fb92d0c5395eebd25a50860b4cb12707dae5e9;hb=83177353155da1e778d08f91caefd3fc0dc29944;hp=2f663659e85614a6e3f1a409372fe9c99b62d4dd;hpb=51e9503489f2cee28a076bf52c56185a5283b069;p=xboard.git diff --git a/common.h b/common.h index 2f66365..92fb92d 100644 --- a/common.h +++ b/common.h @@ -5,7 +5,7 @@ * Massachusetts. * * Enhancements Copyright 1992-2001, 2002, 2003, 2004, 2005, 2006, - * 2007, 2008, 2009, 2010, 2011, 2012, 2013, 2014 Free Software Foundation, Inc. + * 2007, 2008, 2009, 2010, 2011, 2012, 2013, 2014, 2015 Free Software Foundation, Inc. * * Enhancements Copyright 2005 Alessandro Scotti * @@ -180,9 +180,13 @@ typedef char *String; #define BOARD_RGHT (gameInfo.boardWidth + gameInfo.holdingsWidth) #define CASTLING (BOARD_RANKS-1) /* [HGM] hide in upper rank */ #define VIRGIN (BOARD_RANKS-2) /* [HGM] pieces not moved */ +#define TOUCHED_W CASTLING][(BOARD_FILES-6) /* [HGM] in upper rank */ +#define TOUCHED_B CASTLING][(BOARD_FILES-5) /* [HGM] in upper rank */ +#define EP_RANK CASTLING][(BOARD_FILES-4) /* [HGM] in upper rank */ +#define EP_FILE CASTLING][(BOARD_FILES-3) /* [HGM] in upper rank */ #define EP_STATUS CASTLING][(BOARD_FILES-2) /* [HGM] in upper rank */ #define HOLDINGS_SET CASTLING][(BOARD_FILES-1) /* [HGM] in upper-right corner*/ -#define ONE ('1'-(BOARD_HEIGHT==10)) /* [HGM] foremost board rank */ +#define ONE ('1'-(BOARD_HEIGHT==10)-appData.rankOffset) /* [HGM] foremost board rank */ #define AAA ('a'-BOARD_LEFT) /* [HGM] leftmost board file */ #define VIRGIN_W 1 /* [HGM] flags in Board[VIRGIN][X] */ #define VIRGIN_B 2 @@ -222,6 +226,7 @@ typedef char *String; #define BELLCHAR '\007' #define NULLCHAR '\000' #define FEATURE_TIMEOUT 10000 /*ms*/ +#define MATE_SCORE 100000 #define CLOCK_FONT 0 #define MESSAGE_FONT 1 @@ -289,18 +294,24 @@ typedef enum { WhiteFerz, WhiteAlfil, WhiteAngel, WhiteMarshall, WhiteWazir, WhiteMan, WhiteCannon, WhiteNightrider, WhiteCardinal, WhiteDragon, WhiteGrasshopper, WhiteSilver, WhiteFalcon, WhiteLance, WhiteCobra, WhiteUnicorn, WhiteLion, - WhiteTokin, WhiteDagger, WhitePCardinal, WhitePDragon, WhiteCat, + WhiteWolf, WhiteCamel, WhiteZebra, WhiteWizard, WhiteAmazon, + WhiteTokin, WhiteClaw, WhitePCardinal, WhitePDragon, WhiteCat, WhitePSword, WhiteMonarch, WhiteMother, WhiteNothing, WhitePRook, WhitePDagger, WhiteDolphin, WhiteStag, WhiteHorned, WhiteEagle, WhiteSword, - WhiteCrown, WhiteHCrown, WhiteHorse, WhiteDrunk, WhitePBishop, WhiteKing, + WhiteCrown, WhiteHCrown, WhiteHorse, WhiteDrunk, WhitePBishop, + WhiteFlying, WhiteViking, WhiteIron, WhiteCopper, WhiteTower, + WhiteKing, BlackPawn, BlackKnight, BlackBishop, BlackRook, BlackQueen, BlackFerz, BlackAlfil, BlackAngel, BlackMarshall, BlackWazir, BlackMan, BlackCannon, BlackNightrider, BlackCardinal, BlackDragon, BlackGrasshopper, BlackSilver, BlackFalcon, BlackLance, BlackCobra, BlackUnicorn, BlackLion, - BlackTokin, BlackDagger, BlackPCardinal, BlackPDragon, BlackCat, + BlackWolf, BlackCamel, BlackZebra, BlackWizard, BlackAmazon, + BlackTokin, BlackClaw, BlackPCardinal, BlackPDragon, BlackCat, BlackPSword, BlackMonarch, BlackMother, BlackNothing, BlackPRook, BlackPDagger, BlackDolphin, BlackStag, BlackHorned, BlackEagle, BlackSword, - BlackCrown, BlackHCrown, BlackHorse, BlackDrunk, BlackPBishop, BlackKing, + BlackCrown, BlackHCrown, BlackHorse, BlackDrunk, BlackPBishop, + BlackFlying, BlackViking, BlackIron, BlackCopper, BlackTower, + BlackKing, EmptySquare, DarkSquare, NoRights, // [HGM] gamestate: for castling rights hidden in board[CASTLING] ClearBoard, WhitePlay, BlackPlay, PromotePiece, DemotePiece /*for use on EditPosition menus*/ @@ -313,6 +324,7 @@ typedef enum { #define DEMOTED (int)WhiteRook - (int)WhiteDragon + (int) #define SHOGI (int)EmptySquare + (int) #define CHUPROMOTED ((int)WhitePDragon - (int)WhiteDragon)*(gameInfo.variant == VariantChu) + PROMOTED +#define CHUDEMOTED ((int)WhiteDragon - (int)WhitePDragon)*(gameInfo.variant == VariantChu) + DEMOTED #define IS_SHOGI(V) ((V) == VariantShogi || (V) == VariantChu) #define IS_LION(V) ((V) == WhiteLion || (V) == BlackLion) @@ -375,7 +387,6 @@ typedef enum { Variant36, /* Temporary name for possible future ICC wild 36 */ VariantShogi, /* [HGM] added variants */ VariantChu, - VariantXiangqi, VariantCourier, VariantGothic, VariantCapablanca, @@ -390,10 +401,11 @@ typedef enum { VariantGreat, VariantTwilight, VariantMakruk, - VariantASEAN, VariantSChess, VariantGrand, VariantSpartan, + VariantXiangqi, + VariantASEAN, VariantLion, VariantChuChess, VariantUnknown /* Catchall for other unknown variants */ @@ -425,7 +437,6 @@ typedef enum { "wild36", \ "shogi", \ "chu", \ - "xiangqi", \ "courier", \ "gothic", \ "capablanca", \ @@ -440,12 +451,13 @@ typedef enum { "great",\ "twilight",\ "makruk",\ - "asean",\ "seirawan",\ "grand",\ "spartan",\ + "xiangqi", \ + "asean",\ "lion",\ - "chuchess",\ + "elven",\ "unknown" \ } @@ -481,6 +493,7 @@ typedef struct { char *pgnName[ENGINES]; Boolean firstPlaysBlack; Boolean noChessProgram; + char *positionDir; char *host[ENGINES]; char *themeNames; char *pieceDirectory; @@ -507,6 +520,7 @@ typedef struct { char *loadGameFile; int loadGameIndex; /* game # within file */ char *saveGameFile; + char *autoInstall; Boolean autoSaveGames; Boolean onlyOwn; /* [HGM] suppress auto-saving of observed games */ char *loadPositionFile; @@ -515,6 +529,7 @@ typedef struct { Boolean fischerCastling;/* [HGM] fischer: allow Fischr castling in any variant */ Boolean matchMode; int matchGames; + Boolean epd; Boolean monoMode; Boolean debugMode; Boolean clockMode; @@ -528,10 +543,12 @@ typedef struct { char *clockFont; char *messageFont; /* WinBoard only */ char *coordFont; - char *font; /* xboard only: all other fonts */ - char *tagsFont; /* WinBoard only */ - char *commentFont; /* WinBoard only */ - char *icsFont; /* WinBoard only */ + char *font; /* xboard only */ + char *tagsFont; + char *commentFont; + char *historyFont; + char *gameListFont; + char *icsFont; Boolean ringBellAfterMoves; Boolean autoCallFlag; Boolean flipView; @@ -631,6 +648,7 @@ typedef struct { int darkBackTextureMode; char * renderPiecesWithFont; /* Name of font for rendering chess pieces */ char * fontToPieceTable; /* Map to translate font character to chess pieces */ + char * inscriptions; /* text (kanji) to write on top of a piece */ int fontBackColorWhite; int fontForeColorWhite; int fontBackColorBlack; @@ -660,6 +678,7 @@ typedef struct { int adjudicateDrawMoves; Boolean autoDisplayComment; Boolean autoDisplayTags; + Boolean pseudo[ENGINES]; /* [HGM] pseudo-engines */ Boolean isUCI[ENGINES]; Boolean hasOwnBookUCI[ENGINES]; char * adapterCommand; @@ -678,6 +697,7 @@ typedef struct { /* [HGM] Board size */ int NrFiles; int NrRanks; + int rankOffset; int holdingsSize; int matchPause; char * pieceToCharTable; @@ -733,6 +753,8 @@ typedef struct { int dateThreshold; int searchMode; int stretch; + int minPieces; + int maxPieces; Boolean ignoreColors; Boolean findMirror; char *userName; @@ -744,6 +766,7 @@ typedef struct { char *logo[ENGINES];/* [HGM] logo */ char *pairingEngine;/* [HGM] pairing */ Boolean autoLogo; + Boolean fixedSize; Boolean noGUI; /* [HGM] fast: suppress all display updates */ char *engOptions[ENGINES]; /* [HGM] options */ char *fenOverride[ENGINES]; @@ -764,6 +787,7 @@ typedef struct { Boolean autoCopyPV; Boolean pieceMenu; Boolean sweepSelect; + Boolean monoMouse; Boolean whitePOV; Boolean scoreWhite; Boolean pvSAN[ENGINES]; @@ -826,6 +850,7 @@ typedef struct { int whiteRating; /* -1 if unknown */ int blackRating; /* -1 if unknown */ VariantClass variant; + char *variantName; char *outOfBook; /* [AS] Move and score when engine went out of book */ int boardWidth; /* [HGM] adjustable board size */ int boardHeight;