Spades Version 2.12, by Greg Stelmack, April 2, 1992.
*** NOTE: Address change near bottom from version 1.2 documentation ***
*** ALSO NOTE: System Software 2.xx is now REQUIRED to run Spades ***
"Spades" is a program written to play the card game Spades. It may be
run from the CLI or the Workbench. The files required to play are "Spades"
and "Spades.images", and both must be in the same directory. NOTE: Spades
now requires AmigaDOS 2.xx to run. This is because Spades is essentially
a tool for me to learn Amiga programming (I have made only $5 off of it),
and I am trying out some of the 2.xx stuff as I modify it.
This is a one player version of Spades -- you play one hand, and the
computer plays your partner and two opponents. The program plays by the
following rules adopted by my friends and I here at the University of South
Florida:
1) Four players are found, divided into two partnerships of two
players each. Partners sit opposite each other.
2) A dealer is randomly picked. Each player receives 13 cards from a
standard 52-card deck dealt clockwise starting with the player on the
dealer's left. On successive hands, the deal passes to the left.
3) Starting to the left of the dealer, each player bids the number of
tricks he feels his hand can take. Bidding passes clockwise. A
partnership's bid is the total of the two partners' bids. A partnership
must take this total number of tricks.
4) Play starts with the player to the left of the dealer and passes
clockwise. The only rule about leading is that spades may not be lead until
spades have been broken (i.e., played during a hand), unless a player holds
only spades.
5) Players must follow suit -- if you have a card of the suit lead,
you must play it. Otherwise, any suit may be played. Play ends with the
player to the right of the leader. In other words, each player plays one
card.
6) Highest card of the suit lead, or highest spade if a spade has been
played, wins the trick. Cards rank 2 lowest through Ace highest. The trick
winner scores one trick for his partnership and then leads for the next
trick.
7) After all 13 tricks in a hand have been taken, scores are totaled.
If a partnership takes at least as many tricks as they bid, they get 10
points for each trick they bid and one point for each trick they took over
their bid. If a partnership fails to take the number of tricks they bid,
they lose 10 points for each trick they bid. If NIL bids are in effect, and
a player bid zero tricks and took zero, his side scores 100 points. If a
player bid zero and took at least one trick, his side loses 100 points. If
Bags are in effect, and a team has accumulated 10 or more overtricks, they
lose 100 points. Negative scores are possible.
8) Deal passes to the left for another hand. First team to 500, or the
team with the highest score if both cross 500, wins.
When the program is first started, the computer will randomly deal out
cards to each player until the Ace of Spades is dealt. This player becomes
the dealer. The computer will then deal the cards. You will see your hand
at the bottom of the screen. Your partner sits across from you (at the top
of the screen), and your opponents are to either side of you. The computer
players will bid automatically. Their bids will appear as numbers in front
of the positions at which they are sitting.
When it is your turn to bid, a black bid box will appear in the lower
right-hand corner of the screen. Use the left mouse button to select your
bid. Clicking on the plus sign will raise your bid one trick. Clicking on
the minus sign will lower your bid one trick. Clicking on OK will accept
your bid. Selecting the Suggest option from the Game menu (or typing Right-
Amiga-s on the keyboard) will cause the computer to suggest a bid for you.
After all bids have been entered, the computer will pause for you to
examine the bids. When you are ready to play, click the left mouse button.
Cards will then be played. Cards played by a computer player will
appear in the appropriate position on the screen. When it is your turn to
play, the computer will prompt you. Simply point at the card you want to
play and click the left mouse button. Again, selecting Suggest from the
Game menu will cause the computer to suggest a card for you to play (it
will mark it with an asterisk).
Note that the computer will not let you play an illegal card. If
nothing happens when you click, you are either trying to lead spades before
they have been broken or you are not following the lead suit when you can.
After all cards in the trick have been played, the computer will place
an asterisk in front of the winning card and update the trick count. If
this was also the last trick in the hand, it will update the scores. It
will then pause for you to look at all the cards that were played. When you
are ready to continue, click the left mouse button.
This cycle will continue until a winner is found. The program will
then display a final score screen and ask whether or not you would like to
play again. Clicking YES will cause the game to start over. Clicking NO
will bring you back to the environment you started the game from. Note that
the game may be quit at any time by selecting Quit from the Project menu.
There are now several menus with the game. Under the Project menu,
there are New Game (start a new game), Save Hand (more in a minute),
Print Hand (not yet implemented), About (shows some information about
myself), and Quit (exit the game). Under the Game menu, there are NIL Bids
(toggles the NIL rule on and off -- the rule is in effect when checked),
Bags (toggles the Bags rule on and off -- the rule is in effect when
checked), and Suggest (suggest a bid or play as listed above). New options
may be added here later.
The Save Hand menu option is a toggle. As long as it is checked, each
hand will be appended to the file "Spades.save" in the current directory.
This option has been added for two reasons: so you can review hands later,
and so that you can send me this file with a hand you think the computer
goofed up on. If you see a mistake, turn this option on, and then mail or
E-Mail me a copy of that file, along with the play you feel the computer
should have made and why. I will use this to help enhance the computer
players. NOTE: If you leave this option on, the Spades.save file can get
quite large. Remember to clean it up from time to time. Spades creates this
file if it doesn't exist, so don't worry about keeping a copy around.
For Programmers:
The source code should be included with the program. The game is
written in C and compiled using SAS/C 5.10b. I hope that anyone out there
interested in designing their own card games will find this code useful.
Note that the "Spades.images" file contains all the data necessary to draw
the cards. The reader routine is in the procedure "OpenAll". Feel free to
use any or all of the code or images in your own programs. The current
version was compiled with the following command for each source file:
LC -ma -rr -O -cf -cs -E -Li -q10e -q10w -ms -N SourceFile.c
and then all were linked together into the Spades executable (Well,
actually I now use the Workbench interface, but this is the equivalent
command line for the options I used...)
The program (as of version 2.10) has been broken up into several
source files. Since I use the Workbench interface for SAS/C, I do not have
a Makefile for it, but I have included the SASCOPTS file that I use for
compiling.
Copyright Notice:
This program is copyright 1990 by Gregory M. Stelmack. However, I give
permission for anyone to freely distribute this program as long as this
file and the by-line in the title bar of the game remains, and they make no
profit from its distribution (cost of media may be charged -- this is an
implicit OK for Fred Fish to put Spades in his collection). Also, you may
use any of the code for your own programs, but please remember to give
credit where credit is due. I cannot be held responsible for damage that
occurs as a result of the use/misuse of this program, but note that I have
made every effort to make sure it will work properly.
If you find problems, useful enhancements, new rules I may want to
include, or if you would like to send a donation (say 5 or 10 dollars) to
cover my costs (computer, compiler, tools, education, etc.), my address is:
Gregory M. Stelmack
8723 Del Rey Ct. #11-A
Tampa, FL 33617
Feel free to send any comments or suggestions to the above address.
E-mail to: stelmackeggo.csee.usf.edu
BBS: Simply Amazing! (813)977-3940 in Tampa: GREG STELMACK
VERSION CHANGES:
Changes 1.0 to 1.1:
Removed need for Spades.font. Card data is now stored in
Spades.images, and this file is read in at run-time.
Added title graphics.
Added routine for choosing dealer.
First release version.
Changes 1.1 to 1.11:
Corrected a memory allocation and fragmentation bug. The program was
only freeing a portion of its allocated memory. It now frees all of it.
Thanks to Juan Orlandini for catching this.
Added a few prompts for mouse clicks where the program used to just
pause.
Changes 1.11 to 1.12:
Changed the LIBRARY_VERSION in the OpenLibrary() calls to zero. This
is an attempt to let the program run under pre-1.3 Workbench, but I make no
guarantees.
Changes 1.12 to 1.20:
Some of the strategy and bidding routines have been slightly modified.
Hopefully the computer plays a little better now, but there is room for a
little more improvement. Maybe I'll have some time this Summer...
Added a HIDE gadget in the Window TitleBar. Allows Spades to move to
the background so you can do something else if you get bored :).
Changes 1.20 to 2.00:
New images! Now the face cards and aces look like real face cards and
aces :).
New user-interface. Menus have been added to support the optional
rules (see below). Errors now bring up requestors, which allowed the
removal of stdio. Unfortunately, I use EasyRequest() from V36 of the
Intuition library, so you now need AmigaDOS 2.xx to use Spades :(. Window
is now a backdrop window, and the screen's titlebar is visible, meaning
the screen may be shoved to the back or dragged like any other Intuition
screen.
The rules for NIL bids and Bags have been added. Brief explanation:
bids allow you to bid zero, and if you take no tricks gain 100 points. If
you take at least one trick, you lose 100 points. Bags refer to overtricks --
if your team accumulates 10 overtricks over a series of hands, you lose 100
points. Unfortunately, the computer players do not yet know about these
new rules. They are, however, optional, so they may be turned on and off at
will (the default is OFF).
Removed the title graphics (no real added value, and the executable is
now MUCH smaller).
Changes 2.00 to 2.10:
Broke the source code up into several files to make room for future
enhancements. Implemented the Save Hand menu option. More extensive use
of System 2.0 features, including use of GadTools for Menu creation and
layout. Improved the computer players to now take the optional rules into
account.
Changes 2.10 to 2.11:
I stupidly called EasyRequest() to display every error message,
including the one when Intuition can't be opened! I can't come up with a
good way of doing this short of going back to standard I/O, or including
lots of code for this one case, so for right now the program will just
quietly closed if Intuition cannot be opened. This generally happens when
Spades is run under 1.3, which it no longer will.
Changes 2.11 to 2.12:
If a game was started by selecting "New Game" from the menu, it was
impossible to exit the game from the final screen. Selecting the "NO"
button would just restart Spades. I still don't know why this happened
(tracing seemed to show a random jump into my ReadMouse() routine), but
I redid the logic (FinishRoutine() now directly calls WrapUp(), and the
AllDone flag has been eliminated) and it works properly now.
FUTURE ENHANCEMENTS PLANNED (time permitting, of course):
Strategy: Computer still occasionally does something dumb, mostly
because it has difficulty looking into the future and predicting who is out
of what. I need to make it smarter. Also, it bids poorly (too low) with
lots of Spades in its hand.
Options: Implement the Print Hand option (although you could just
print the Spades.save file.
1.3 version: If enough people ask for it...
|