tset2.pp 9.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392
  1. (*********************************************************************)
  2. (* Copyright (C) 1998, Carl Eric Codere *)
  3. (*********************************************************************)
  4. (* FPC (Free Pascal compiler) testsuite: SETS *)
  5. (* Tests the following: in, +, -, *, assignments. *)
  6. (* for small sets amd large sets, both with constants *)
  7. (* and variables. *)
  8. (*********************************************************************)
  9. type
  10. myenum = (dA,dB,dC,dd,dedf,dg,dh,di,dj,dk,dl,dm,dn);
  11. tasmop = (A_ABCD,
  12. A_ADD,A_ADDA,A_ADDI,A_ADDQ,A_ADDX,A_AND,A_ANDI,
  13. A_ASL,A_ASR,A_BCC,A_BCS,A_BEQ,A_BGE,A_BGT,A_BHI,
  14. A_BLE,A_BLS,A_BLT,A_BMI,A_BNE,A_BPL,A_BVC,A_BVS,
  15. A_BCHG,A_BCLR,A_BRA,A_BSET,A_BSR,A_BTST,A_CHK,
  16. A_CLR,A_CMP,A_CMPA,A_CMPI,A_CMPM,A_DBCC,A_DBCS,A_DBEQ,A_DBGE,
  17. A_DBGT,A_DBHI,A_DBLE,A_DBLS,A_DBLT,A_DBMI,A_DBNE,A_DBRA,
  18. A_DBPL,A_DBT,A_DBVC,A_DBVS,A_DBF,A_DIVS,A_DIVU,
  19. A_EOR,A_EORI,A_EXG,A_ILLEGAL,A_EXT,A_JMP,A_JSR,
  20. A_LEA,A_LINK,A_LSL,A_LSR,A_MOVE,A_MOVEA,A_MOVEI,A_MOVEQ,
  21. A_MOVEM,A_MOVEP,A_MULS,A_MULU,A_NBCD,A_NEG,A_NEGX,
  22. A_NOP,A_NOT,A_OR,A_ORI,A_PEA,A_ROL,A_ROR,A_ROXL,
  23. A_ROXR,A_RTR,A_RTS,A_SBCD,A_SCC,A_SCS,A_SEQ,A_SGE,
  24. A_SGT,A_SHI,A_SLE,A_SLS,A_SLT,A_SMI,A_SNE,
  25. A_SPL,A_ST,A_SVC,A_SVS,A_SF,A_SUB,A_SUBA,A_SUBI,A_SUBQ,
  26. A_SUBX,A_SWAP,A_TAS,A_TRAP,A_TRAPV,A_TST,A_UNLK,
  27. A_RTE,A_RESET,A_STOP,
  28. { MC68010 instructions }
  29. A_BKPT,A_MOVEC,A_MOVES,A_RTD,
  30. { MC68020 instructions }
  31. A_BFCHG,A_BFCLR,A_BFEXTS,A_BFEXTU,A_BFFFO,
  32. A_BFINS,A_BFSET,A_BFTST,A_CALLM,A_CAS,A_CAS2,
  33. A_CHK2,A_CMP2,A_DIVSL,A_DIVUL,A_EXTB,A_PACK,A_RTM,
  34. A_TRAPCC,A_TRACS,A_TRAPEQ,A_TRAPF,A_TRAPGE,A_TRAPGT,
  35. A_TRAPHI,A_TRAPLE,A_TRAPLS,A_TRAPLT,A_TRAPMI,A_TRAPNE,
  36. A_TRAPPL,A_TRAPT,A_TRAPVC,A_TRAPVS,A_UNPK,
  37. { FPU Processor instructions - directly supported only. }
  38. { IEEE aware and misc. condition codes not supported }
  39. A_FABS,A_FADD,
  40. A_FBEQ,A_FBNE,A_FBNGT,A_FBGT,A_FBGE,A_FBNGE,
  41. A_FBLT,A_FBNLT,A_FBLE,A_FBGL,A_FBNGL,A_FBGLE,A_FBNGLE,
  42. A_FDBEQ,A_FDBNE,A_FDBGT,A_FDBNGT,A_FDBGE,A_FDBNGE,
  43. A_FDBLT,A_FDBNLT,A_FDBLE,A_FDBGL,A_FDBNGL,A_FDBGLE,A_FBDNGLE,
  44. A_FSEQ,A_FSNE,A_FSGT,A_FSNGT,A_FSGE,A_FSNGE,
  45. A_FSLT,A_FSNLT,A_FSLE,A_FSGL,A_FSNGL,A_FSGLE,A_FSNGLE,
  46. A_FCMP,A_FDIV,A_FMOVE,A_FMOVEM,
  47. A_FMUL,A_FNEG,A_FNOP,A_FSQRT,A_FSUB,A_FSGLDIV,
  48. A_FSFLMUL,A_FTST,
  49. A_FTRAPEQ,A_FTRAPNE,A_FTRAPGT,A_FTRAPNGT,A_FTRAPGE,A_FTRAPNGE,
  50. A_FTRAPLT,A_FTRAPNLT,A_FTRAPLE,A_FTRAPGL,A_FTRAPNGL,A_FTRAPGLE,A_FTRAPNGLE,
  51. { Protected instructions }
  52. A_CPRESTORE,A_CPSAVE,
  53. { FPU Unit protected instructions }
  54. { and 68030/68851 common MMU instructions }
  55. { (this may include 68040 MMU instructions) }
  56. A_FRESTORE,A_FSAVE,A_PFLUSH,A_PFLUSHA,A_PLOAD,A_PMOVE,A_PTEST,
  57. { Useful for assembly langage output }
  58. A_LABEL,A_NONE);
  59. Function X(y:myenum): myenum;
  60. Begin
  61. x:=y;
  62. end;
  63. Procedure SecondInSets;
  64. { SET_IN_BYTE TESTS }
  65. var
  66. op,op2 : tasmop;
  67. oplist: set of tasmop;
  68. Begin
  69. Write('TESTING SET_IN_BYTE:');
  70. oplist:=[];
  71. op:=A_JSR;
  72. if A_JSR in oplist then
  73. WriteLn('A_JSR in [] FAILED.')
  74. else
  75. Writeln('A_JSR in [] PASSED.');
  76. if op in oplist then
  77. WriteLn('op(A_JSR) in [] FAILED.')
  78. else
  79. Writeln('op (A_JSR) in [] PASSED.');
  80. op:=A_MOVE;
  81. oplist:=oplist+[A_MOVE];
  82. if A_MOVE in oplist then
  83. WriteLn('A_MOVE in ([]+[A_MOVE]) PASSED.')
  84. else
  85. Writeln('A_MOVE in ([]+[A_MOVE]) FAILED.');
  86. if op in oplist then
  87. WriteLn('op(A_MOVE) in ([]+[A_MOVE]) PASSED.')
  88. else
  89. Writeln('op(A_MOVE) in ([]+[A_MOVE]) FAILED.');
  90. op:=A_MOVE;
  91. oplist:=[];
  92. oplist:=[A_SUB]+[op];
  93. op2:=A_MOVE;
  94. if A_MOVE in oplist then
  95. WriteLn('A_MOVE in ([A_SUB]+[op(A_MOVE)]) PASSED.')
  96. else
  97. Writeln('A_MOVE in ([A_SUB]+[op(A_MOVE)]) FAILED.');
  98. if op2 in oplist then
  99. WriteLn('op2(A_MOVE) in ([A_SUB]+[op(A_MOVE)]) PASSED.')
  100. else
  101. Writeln('op2(A_MOVE) in ([A_SUB]+[op(A_MOVE)]) FAILED.');
  102. end;
  103. Procedure SetSetByte;
  104. { SET_SET_BYTE }
  105. var
  106. op : tasmop;
  107. oplist: set of tasmop;
  108. Begin
  109. Write('TESTING SET_SET_BYTE(1):');
  110. op:=A_LABEL;
  111. oplist:=[];
  112. oplist:=oplist+[op];
  113. if op in oplist then
  114. Begin
  115. WriteLn(' PASSED.');
  116. end
  117. else
  118. Begin
  119. WriteLn(' FAILED.');
  120. end;
  121. Write('TESTING INCLUDE:');
  122. op:=A_RTE;
  123. include(oplist,op);
  124. if op in oplist then
  125. Begin
  126. WriteLn(' PASSED.');
  127. end
  128. else
  129. Begin
  130. WriteLn(' FAILED.');
  131. end;
  132. end;
  133. Procedure SetAddSets;
  134. { SET_ADD_SETS }
  135. var
  136. op2list :set of tasmop;
  137. oplist: set of tasmop;
  138. Begin
  139. op2list:=[];
  140. oplist:=[];
  141. oplist:=[A_MOVE]+[A_JSR];
  142. op2list:=[A_LABEL];
  143. oplist:=op2list+oplist;
  144. if A_MOVE in oplist then
  145. if A_LABEL in oplist then
  146. if A_JSR in oplist then
  147. WriteLn('TESTING SET_ADD_SETS: PASSED.')
  148. else
  149. WriteLn('TESTING SET_ADD_SETS: FAILED.')
  150. else
  151. WriteLn('TESTING SET_ADD_SETS: FAILED.')
  152. else
  153. WriteLn('TESTING SET_ADD_SETS: FAILED.')
  154. end;
  155. Procedure SetSubsets;
  156. { SET_SUB_SETS }
  157. var
  158. op2list :set of tasmop;
  159. oplist: set of tasmop;
  160. Begin
  161. op2list:=[];
  162. oplist:=[];
  163. oplist:=[A_MOVE]+[A_JSR];
  164. op2list:=[A_MOVE]+[A_JSR];
  165. oplist:=op2list-oplist;
  166. if (A_MOVE in oplist) or (A_LABEL in oplist) or (A_JSR in oplist) then
  167. WriteLn('TESTING SET_SUB_SETS: FAILED.')
  168. else
  169. WriteLn('TESTING SET_SUB_SETS: PASSED.');
  170. oplist := [A_MOVE,A_RTE];
  171. exclude(oplist,A_MOVE);
  172. if (A_MOVE in oplist) then
  173. WriteLn('TESTING EXCLUDE: FAILED.')
  174. else
  175. WriteLn('TESTING EXCLUDE: PASSED.')
  176. end;
  177. Procedure SetCompSets;
  178. { SET_COMP_SETS }
  179. var
  180. op2list :set of tasmop;
  181. oplist: set of tasmop;
  182. Begin
  183. op2list:=[];
  184. oplist:=[];
  185. oplist:=[A_MOVE]+[A_JSR];
  186. op2list:=[A_MOVE]+[A_JSR];
  187. if oplist=op2list then
  188. WriteLn('TESTING SET_COMP_SETS(1): PASSED.')
  189. else
  190. WriteLn('TESTING SET_COMP_SETS(1): FAILED.');
  191. oplist:=[A_MOVE];
  192. if oplist=op2list then
  193. WriteLn('TESTING SET_COMP_SETS(2): FAILED.')
  194. else
  195. WriteLn('TESTING SET_COMP_SETS(2): PASSED.');
  196. end;
  197. Procedure SetMulSets;
  198. { SET_COMP_SETS }
  199. var
  200. op2list :set of tasmop;
  201. oplist: set of tasmop;
  202. Begin
  203. op2list:=[];
  204. oplist:=[];
  205. oplist:=[A_MOVE]+[A_JSR];
  206. op2list:=[A_MOVE];
  207. oplist:=oplist*op2list;
  208. if A_JSR in oplist then
  209. WriteLn('TESTING SET_MUL_SETS(1): FAILED.')
  210. else
  211. WriteLn('TESTING SET_MUL_SETS(1): PASSED.');
  212. if A_MOVE in oplist then
  213. WriteLn('TESTING SET_MUL_SETS(2): PASSED.')
  214. else
  215. WriteLn('TESTING SET_MUL_SETS(2): FAILED.')
  216. end;
  217. {------------------------------ TESTS FOR SMALL VALUES ---------------------}
  218. Procedure SmallInSets;
  219. { SET_IN_BYTE TESTS }
  220. var
  221. op : myenum;
  222. oplist: set of myenum;
  223. Begin
  224. Write('TESTING IN_BYTE:');
  225. oplist:=[];
  226. op:=Dn;
  227. if op in oplist then
  228. WriteLn(' FAILED.');
  229. op:=dm;
  230. oplist:=oplist+[Dm];
  231. if op in oplist then
  232. WriteLn(' PASSED.');
  233. end;
  234. Procedure SmallSetByte;
  235. { SET_SET_BYTE }
  236. var
  237. op : myenum;
  238. oplist: set of myenum;
  239. Begin
  240. Write('TESTING SET_BYTE(1):');
  241. op:=DA;
  242. oplist:=[];
  243. oplist:=oplist+[op];
  244. if op in oplist then
  245. Begin
  246. WriteLn(' PASSED.');
  247. end
  248. else
  249. Begin
  250. WriteLn(' FAILED.');
  251. end;
  252. end;
  253. Procedure SmallAddSets;
  254. { SET_ADD_SETS }
  255. var
  256. op2list :set of myenum;
  257. oplist: set of myenum;
  258. Begin
  259. op2list:=[];
  260. oplist:=[];
  261. oplist:=[DA]+[DC];
  262. op2list:=[DB];
  263. oplist:=op2list+oplist;
  264. if DA in oplist then
  265. if DC in oplist then
  266. if DB in oplist then
  267. WriteLn('TESTING SET_ADD_SETS: PASSED.')
  268. else
  269. WriteLn('TESTING ADD_SETS: FAILED.')
  270. else
  271. WriteLn('TESTING ADD_SETS: FAILED.')
  272. else
  273. WriteLn('TESTING ADD_SETS: FAILED.')
  274. end;
  275. Procedure SmallSubsets;
  276. { SET_SUB_SETS }
  277. var
  278. op2list :set of myenum;
  279. oplist: set of myenum;
  280. Begin
  281. op2list:=[];
  282. oplist:=[];
  283. oplist:=[DA]+[DC];
  284. op2list:=[DA]+[DC];
  285. oplist:=op2list-oplist;
  286. if (DA in oplist) or (DB in oplist) or (DC in oplist) then
  287. WriteLn('TESTING SUB_SETS: FAILED.')
  288. else
  289. WriteLn('TESTING SUB_SETS: PASSED.')
  290. end;
  291. Procedure SmallCompSets;
  292. { SET_COMP_SETS }
  293. var
  294. op2list :set of myenum;
  295. oplist: set of myenum;
  296. Begin
  297. op2list:=[];
  298. oplist:=[];
  299. oplist:=[DA]+[DC];
  300. op2list:=[DA]+[DC];
  301. if oplist=op2list then
  302. WriteLn('TESTING COMP_SETS(1): PASSED.')
  303. else
  304. WriteLn('TESTING COMP_SETS(1): FAILED.');
  305. oplist:=[DA];
  306. if oplist=op2list then
  307. WriteLn('TESTING COMP_SETS(2): FAILED.')
  308. else
  309. WriteLn('TESTING COMP_SETS(2): PASSED.');
  310. end;
  311. Procedure SmallMulSets;
  312. { SET_COMP_SETS }
  313. var
  314. op2list :set of myenum;
  315. oplist: set of myenum;
  316. Begin
  317. op2list:=[];
  318. oplist:=[];
  319. oplist:=[DA]+[DC];
  320. op2list:=[DA];
  321. oplist:=oplist*op2list;
  322. if DC in oplist then
  323. WriteLn('TESTING MUL_SETS(1): FAILED.')
  324. else
  325. WriteLn('TESTING MUL_SETS(1): PASSED.');
  326. if DA in oplist then
  327. WriteLn('TESTING MUL_SETS(2): PASSED.')
  328. else
  329. WriteLn('TESTING MUL_SETS(2): FAILED.')
  330. end;
  331. const
  332. b: myenum = (dA);
  333. var
  334. enum: set of myenum;
  335. oplist: set of tasmop;
  336. l : word;
  337. Begin
  338. { small sets }
  339. enum:=[];
  340. { add }
  341. enum:=enum+[da];
  342. { subtract }
  343. enum:=enum-[da];
  344. if DA in enum then
  345. WriteLn('Found A_LABEL');
  346. { very large sets }
  347. { copy loop test }
  348. WRITELN('LARGE SETS:');
  349. oplist := [A_LABEL];
  350. { secondin test }
  351. if A_LABEL in oplist then
  352. WriteLn('TESTING SIMPLE SECOND_IN: PASSED.');
  353. { }
  354. oplist:=[];
  355. if A_LABEL in oplist then
  356. WriteLn('SECOND IN FAILED.');
  357. SecondinSets;
  358. SetSetByte;
  359. SetAddSets;
  360. SetSubSets;
  361. SetCompSets;
  362. SetMulSets;
  363. WRITELN('SMALL SETS:');
  364. SmallInSets;
  365. SmallAddSets;
  366. SmallSubSets;
  367. SmallCompSets;
  368. SmallMulSets;
  369. l:=word(A_CPRESTORE);
  370. if l = word(A_CPRESTORE) then
  371. Begin
  372. end;
  373. end.