Short: a card game Author: stelmack@eggo.csee.usf.edu (Greg Stelmack) Uploader: sgberg charon bloomington in us (Stefan G Berg) Type: game/think Architecture: m68k-amigaos 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: stelmack@eggo.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...