It seems the above diagram does approximately what is needed. The diagram script initially choked on only black having a piece that can castle; the code for determining the castling partners only considered white pieces, assuming symmetry, and thus left things undefined, which propagated through the calculation to finally make everything undefined. I fixed this now.
I also had some problems with the implementation of baring. This counted only non-royal pieces. But in this variant black should not suffer even from being totally bared, and I thought I was clever by defining the King as a piece that should be counted. But the old code overruled that. I changed the code so that it now only discounts the royal from the total number of pieces when it was not explicitly defined by a royal=N line (in which case the last piece in the table is taken to be royal). This allowed me to define the black King as a baring piece as well as a royal, so that being bared is the same as losing your King. For white, however, the Rooks and Archbishops are baring pieces, and the Fool an extinction royal.
Another problem was the promotion. I could have defined it as Shogi promotions, as there is apparenly no choice. But then white and black pawns would have to be different piece types, as they promote differently. (And it would allow youto defer.) So I opted for another solution: I allow promotion to Hunter or Fool, but only to pieces 'in hand'. And the white hand starts with only 10 Fools, and the black hand with only 10 Hunters.
The capture restriction on Fools is implemented by a BadZone JavaScript routine embedded in the page. The AI pays attention to this. For castling I just took flexible castling.
It seems the above diagram does approximately what is needed. The diagram script initially choked on only black having a piece that can castle; the code for determining the castling partners only considered white pieces, assuming symmetry, and thus left things undefined, which propagated through the calculation to finally make everything undefined. I fixed this now.
I also had some problems with the implementation of baring. This counted only non-royal pieces. But in this variant black should not suffer even from being totally bared, and I thought I was clever by defining the King as a piece that should be counted. But the old code overruled that. I changed the code so that it now only discounts the royal from the total number of pieces when it was not explicitly defined by a royal=N line (in which case the last piece in the table is taken to be royal). This allowed me to define the black King as a baring piece as well as a royal, so that being bared is the same as losing your King. For white, however, the Rooks and Archbishops are baring pieces, and the Fool an extinction royal.
Another problem was the promotion. I could have defined it as Shogi promotions, as there is apparenly no choice. But then white and black pawns would have to be different piece types, as they promote differently. (And it would allow youto defer.) So I opted for another solution: I allow promotion to Hunter or Fool, but only to pieces 'in hand'. And the white hand starts with only 10 Fools, and the black hand with only 10 Hunters.
The capture restriction on Fools is implemented by a BadZone JavaScript routine embedded in the page. The AI pays attention to this. For castling I just took flexible castling.