home *** CD-ROM | disk | FTP | other *** search
/ Club Amiga de Montreal - CAM / CAM_CD_1.iso / files / 605b.lha / Spades_v2.10 / Spades.readme.pp / Spades.readme
Encoding:
Text File  |  1992-02-10  |  11.4 KB  |  201 lines

  1. Spades Version 2.10, by Greg Stelmack, February 3, 1992.
  2.  
  3. *** NOTE: Address change near bottom from version 1.2 documentation ***
  4.  
  5.      "Spades" is a program written to play the card game Spades. It may be
  6. run from the CLI or the Workbench. The files required to play are "Spades"
  7. and "Spades.images", and both must be in the same directory. NOTE: Spades
  8. now requires AmigaDOS 2.xx to run. This is because Spades is essentially
  9. a tool for me to learn Amiga programming (I have made only $5 off of it),
  10. and I am trying out some of the 2.xx stuff as I modify it.
  11.      This is a one player version of Spades -- you play one hand, and the
  12. computer plays your partner and two opponents. The program plays by the
  13. following rules adopted by my friends and I here at the University of South
  14. Florida:
  15.      1) Four players are found, divided into two partnerships of two
  16. players each. Partners sit opposite each other.
  17.      2) A dealer is randomly picked. Each player receives 13 cards from a
  18. standard 52-card deck dealt clockwise starting with the player on the
  19. dealer's left. On successive hands, the deal passes to the left.
  20.      3) Starting to the left of the dealer, each player bids the number of
  21. tricks he feels his hand can take. Bidding passes clockwise. A
  22. partnership's bid is the total of the two partners' bids. A partnership
  23. must take this total number of tricks.
  24.      4) Play starts with the player to the left of the dealer and passes
  25. clockwise. The only rule about leading is that spades may not be lead until
  26. spades have been broken (i.e., played during a hand), unless a player holds
  27. only spades.
  28.      5) Players must follow suit -- if you have a card of the suit lead,
  29. you must play it. Otherwise, any suit may be played. Play ends with the
  30. player to the right of the leader. In other words, each player plays one
  31. card.
  32.      6) Highest card of the suit lead, or highest spade if a spade has been
  33. played, wins the trick. Cards rank 2 lowest through Ace highest. The trick
  34. winner scores one trick for his partnership and then leads for the next
  35. trick.
  36.      7) After all 13 tricks in a hand have been taken, scores are totaled.
  37. If a partnership takes at least as many tricks as they bid, they get 10
  38. points for each trick they bid and one point for each trick they took over
  39. their bid. If a partnership fails to take the number of tricks they bid,
  40. they lose 10 points for each trick they bid. If NIL bids are in effect, and
  41. a player bid zero tricks and took zero, his side scores 100 points. If a
  42. player bid zero and took at least one trick, his side loses 100 points. If
  43. Bags are in effect, and a team has accumulated 10 or more overtricks, they
  44. lose 100 points. Negative scores are possible.
  45.      8) Deal passes to the left for another hand. First team to 500, or the
  46. team with the highest score if both cross 500, wins.
  47.  
  48.      When the program is first started, the computer will randomly deal out
  49. cards to each player until the Ace of Spades is dealt. This player becomes
  50. the dealer. The computer will then deal the cards. You will see your hand
  51. at the bottom of the screen. Your partner sits across from you (at the top
  52. of the screen), and your opponents are to either side of you. The computer
  53. players will bid automatically. Their bids will appear as numbers in front
  54. of the positions at which they are sitting.
  55.      When it is your turn to bid, a black bid box will appear in the lower
  56. right-hand corner of the screen. Use the left mouse button to select your
  57. bid. Clicking on the plus sign will raise your bid one trick. Clicking on
  58. the minus sign will lower your bid one trick. Clicking on OK will accept
  59. your bid. Selecting the Suggest option from the Game menu (or typing Right-
  60. Amiga-s on the keyboard) will cause the computer to suggest a bid for you.
  61.      After all bids have been entered, the computer will pause for you to
  62. examine the bids. When you are ready to play, click the left mouse button.
  63.      Cards will then be played. Cards played by a computer player will
  64. appear in the appropriate position on the screen. When it is your turn to
  65. play, the computer will prompt you. Simply point at the card you want to
  66. play and click the left mouse button. Again, selecting Suggest from the
  67. Game menu will cause the computer to suggest a card for you to play (it
  68. will mark it with an asterisk).
  69.      Note that the computer will not let you play an illegal card. If
  70. nothing happens when you click, you are either trying to lead spades before
  71. they have been broken or you are not following the lead suit when you can.
  72.      After all cards in the trick have been played, the computer will place
  73. an asterisk in front of the winning card and update the trick count. If
  74. this was also the last trick in the hand, it will update the scores. It
  75. will then pause for you to look at all the cards that were played. When you
  76. are ready to continue, click the left mouse button.
  77.      This cycle will continue until a winner is found. The program will
  78. then display a final score screen and ask whether or not you would like to
  79. play again. Clicking YES will cause the game to start over. Clicking NO
  80. will bring you back to the environment you started the game from. Note that
  81. the game may be quit at any time by selecting Quit from the Project menu.
  82.  
  83.      There are now several menus with the game. Under the Project menu,
  84. there are New Game (start a new game), Save Hand (more in a minute),
  85. Print Hand (not yet implemented), About (shows some information about
  86. myself), and Quit (exit the game). Under the Game menu, there are NIL Bids
  87. (toggles the NIL rule on and off -- the rule is in effect when checked),
  88. Bags (toggles the Bags rule on and off -- the rule is in effect when
  89. checked), and Suggest (suggest a bid or play as listed above). New options
  90. may be added here later.
  91.      The Save Hand menu option is a toggle. As long as it is checked, each
  92. hand will be appended to the file "Spades.save" in the current directory.
  93. This option has been added for two reasons: so you can review hands later,
  94. and so that you can send me this file with a hand you think the computer
  95. goofed up on. If you see a mistake, turn this option on, and then mail or
  96. E-Mail me a copy of that file, along with the play you feel the computer
  97. should have made and why. I will use this to help enhance the computer
  98. players. NOTE: If you leave this option on, the Spades.save file can get
  99. quite large. Remember to clean it up from time to time. Spades creates this
  100. file if it doesn't exist, so don't worry about keeping a copy around.
  101.  
  102. For Programmers:
  103.      The source code should be included with the program. The game is
  104. written in C and compiled using SAS/C 5.10b. I hope that anyone out there
  105. interested in designing their own card games will find this code useful.
  106. Note that the "Spades.images" file contains all the data necessary to draw
  107. the cards. The reader routine is in the procedure "OpenAll". Feel free to
  108. use any or all of the code or images in your own programs. The current
  109. version was compiled with the following command for each source file:
  110.      LC -ma -rr -O -cf -cs -E -Li -q10e -q10w -ms -N SourceFile.c
  111. and then all were linked together into the Spades executable (Well,
  112. actually I now use the workbench interface, but this is the equivalent
  113. command line for the options I used...)
  114.      The program (as of version 2.10) has been broken up into several
  115. source files. Since I use the Workbench interface for SAS/C, I do not have
  116. a Makefile for it, but I have included the SASCOPTS file that I use for
  117. compiling.
  118.  
  119. Copyright Notice:
  120.      This program is copyright 1990 by Gregory M. Stelmack. However, I give
  121. permission for anyone to freely distribute this program as long as this
  122. file and the by-line in the title bar of the game remains, and they make no
  123. profit from its distribution (cost of media may be charged -- this is an
  124. implicit OK for Fred Fish to put Spades in his collection). Also, you may
  125. use any of the code for your own programs, but please remember to give
  126. credit where credit is due. I cannot be held responsible for damage that
  127. occurs as a result of the use/misuse of this program, but note that I have
  128. made every effort to make sure it will work properly.
  129.      If you find problems, useful enhancements, new rules I may want to
  130. include, or if you would like to send a donation (say 5 or 10 dollars) to
  131. cover my costs (computer, compiler, tools, education, etc.), my address is:
  132.                    Gregory M. Stelmack
  133.                    8723 Del Rey Ct. #11-A
  134.                    Tampa, FL 33617
  135. Feel free to send any comments or suggestions to the above address.
  136. E-mail to: stelmack@eggo.csee.usf.edu
  137. BBS: Simply Amazing! (813)977-3940 in Tampa: GREG STELMACK
  138.  
  139. VERSION CHANGES:
  140.  
  141. Changes 1.0 to 1.1:
  142.      Removed need for Spades.font. Card data is now stored in
  143. Spades.images, and this file is read in at run-time.
  144.      Added title graphics.
  145.      Added routine for choosing dealer.
  146.      First release version.
  147.  
  148. Changes 1.1 to 1.11:
  149.      Corrected a memory allocation and fragmentation bug. The program was
  150. only freeing a portion of its allocated memory. It now frees all of it.
  151. Thanks to Juan Orlandini for catching this.
  152.      Added a few prompts for mouse clicks where the program used to just
  153. pause.
  154.  
  155. Changes 1.11 to 1.12:
  156.      Changed the LIBRARY_VERSION in the OpenLibrary() calls to zero. This
  157. is an attempt to let the program run under pre-1.3 Workbench, but I make no
  158. guarantees.
  159.  
  160. Changes 1.12 to 1.20:
  161.      Some of the strategy and bidding routines have been slightly modified.
  162. Hopefully the computer plays a little better now, but there is room for a
  163. little more improvement. Maybe I'll have some time this Summer...
  164.      Added a HIDE gadget in the Window TitleBar. Allows Spades to move to
  165. the background so you can do something else if you get bored :).
  166.  
  167. Changes 1.20 to 2.00:
  168.      New images! Now the face cards and aces look like real face cards and
  169. aces :).
  170.      New user-interface. Menus have been added to support the optional
  171. rules (see below). Errors now bring up requestors, which allowed the
  172. removal of stdio. Unfortunately, I use EasyRequest() from V36 of the
  173. Intuition library, so you now need AmigaDOS 2.xx to use Spades :(. Window
  174. is now a backdrop window, and the screen's titlebar is visible, meaning
  175. the screen may be shoved to the back or dragged like any other Intuition
  176. screen.
  177.      The rules for NIL bids and Bags have been added. Brief explanation:
  178. bids allow you to bid zero, and if you take no tricks gain 100 points. If
  179. you take at least one trick, you lose 100 points. Bags refer to overtricks --
  180. if your team accumulates 10 overtricks over a series of hands, you lose 100
  181. points. Unfortunately, the computer players do not yet know about these
  182. new rules. They are, however, optional, so they may be turned on and off at
  183. will (the default is OFF).
  184.      Removed the title graphics (no real added value, and the executable is
  185. now MUCH smaller).
  186.  
  187. Changes 2.00 to 2.10:
  188.      Broke the source code up into several files to make room for future
  189. enhancements. Implemented the Save Hand menu option. More extensive use
  190. of System 2.0 features, including use of GadTools for Menu creation and
  191. layout. Improved the computer players to now take the optional rules into
  192. account.
  193.  
  194. FUTURE ENHANCEMENTS PLANNED (time permitting, of course):
  195.      Strategy: Computer still occasionally does something dumb, mostly
  196. because it has difficulty looking into the future and predicting who is out
  197. of what. I need to make it smarter. Also, it bids poorly (too low) with
  198. lots of Spades in its hand.
  199.      Options: Implement the Print Hand option (although you could just
  200. print the Spades.save file.
  201.