tfexpand.pp 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554
  1. { %skiptarget=wince }
  2. {
  3. This file is part of the Free Pascal test suite.
  4. Copyright (c) 1999-2004 by the Free Pascal development team.
  5. Test for possible bugs in Dos.FExpand
  6. See the file COPYING.FPC, included in this distribution,
  7. for details about the copyright.
  8. This program is distributed in the hope that it will be useful,
  9. but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  11. **********************************************************************}
  12. program TFExpand;
  13. {$DEFINE DEBUG}
  14. (* Defining DEBUG causes all the source and target strings *)
  15. (* to be written to the console to make debugging easier. *)
  16. { $DEFINE DIRECT}
  17. (* Defining DIRECT causes direct embedding of fexpand.inc instead *)
  18. (* of using FExpand implementation in (previously compiled) unit Dos. *)
  19. uses
  20. {$ifdef FPC}
  21. PopupErr,
  22. {$endif FPC}
  23. Dos;
  24. {$IFDEF DIRECT}
  25. (* For testing purposes on non-native platforms *)
  26. {$DEFINE VOLUMES}
  27. {$DEFINE NODOTS}
  28. { $DEFINE AMIGA}
  29. { $DEFINE UNIX}
  30. {$DEFINE MACOS}
  31. { $DEFINE FPC_FEXPAND_DRIVES}
  32. { $DEFINE FPC_FEXPAND_UNC}
  33. {$DEFINE FPC_FEXPAND_VOLUMES}
  34. {$DEFINE FPC_FEXPAND_NO_DEFAULT_PATHS}
  35. {$DEFINE FPC_FEXPAND_DRIVESEP_IS_ROOT}
  36. { $DEFINE FPC_FEXPAND_DIRSEP_IS_UPDIR}
  37. {$DEFINE FPC_FEXPAND_NO_DOTS_UPDIR}
  38. { $DEFINE FPC_FEXPAND_NO_CURDIR}
  39. { $DEFINE FPC_FEXPAND_TILDE}
  40. { $DEFINE FPC_FEXPAND_MULTIPLE_UPDIR}
  41. {$DEFINE FPC_FEXPAND_DIRSEP_IS_CURDIR}
  42. { $DEFINE FPC_FEXPAND_GETENV_PCHAR}
  43. {$ENDIF DIRECT}
  44. {$IFDEF LINUX}
  45. {$IFNDEF UNIX}
  46. {$DEFINE UNIX}
  47. {$ENDIF UNIX}
  48. {$ENDIF LINUX}
  49. {$IFDEF AMIGA}
  50. {$IFNDEF HASAMIGA}
  51. {$DEFINE HASAMIGA}
  52. {$ENDIF HASAMIGA}
  53. {$ENDIF AMIGA}
  54. {$IFDEF HASAMIGA}
  55. {$DEFINE VOLUMES}
  56. {$DEFINE NODRIVEC}
  57. {$DEFINE NODOTS}
  58. {$ENDIF HASAMIGA}
  59. {$IFDEF NETWARE}
  60. {$DEFINE VOLUMES}
  61. {$DEFINE NODRIVEC}
  62. {$ENDIF NETWARE}
  63. {$IFDEF UNIX}
  64. {$DEFINE NODRIVEC}
  65. {$ENDIF UNIX}
  66. {$IFDEF MACOS}
  67. {$DEFINE VOLUMES}
  68. {$DEFINE NODRIVEC}
  69. {$DEFINE NODOTS}
  70. {$ENDIF MACOS}
  71. const
  72. {$IFNDEF NODRIVEC}
  73. CC = 'C:';
  74. {$ENDIF NODRIVEC}
  75. {$IFNDEF FPC}
  76. FileNameCasePreserving = false;
  77. DirectorySeparator = '\';
  78. DirectorySeparator2 = '\';
  79. DirSep = '\';
  80. CDrive = 'C:';
  81. DriveSep = ':';
  82. {$ELSE FPC}
  83. (* Used for ChDir/MkDir *)
  84. DirectorySeparator2 = System.DirectorySeparator;
  85. {$IFDEF DIRECT}
  86. {$IFDEF MACOS}
  87. DirectorySeparator = ':';
  88. LFNSupport = true;
  89. FileNameCasePreserving = true;
  90. {$ELSE MACOS}
  91. {$IFDEF UNIX}
  92. DirectorySeparator = '/';
  93. DriveSeparator = '/';
  94. FileNameCasePreserving = true;
  95. {$ELSE UNIX}
  96. {$IFDEF HASAMIGA}
  97. DirectorySeparator = '/';
  98. FileNameCasePreserving = true;
  99. {$ELSE HASAMIGA}
  100. DirectorySeparator = '\';
  101. FileNameCasePreserving = false;
  102. {$ENDIF HASAMIGA}
  103. {$ENDIF UNIX}
  104. {$ENDIF MACOS}
  105. {$ENDIF DIRECT}
  106. DirSep = DirectorySeparator;
  107. {$IFDEF MACOS}
  108. DriveSep = '';
  109. {$ELSE MACOS}
  110. DriveSep = DriveSeparator;
  111. {$ENDIF MACOS}
  112. {$IFDEF UNIX}
  113. CDrive = '';
  114. {$ELSE UNIX}
  115. {$IFDEF MACOS}
  116. CDrive = 'C';
  117. {$ELSE MACOS}
  118. {$IFDEF HASAMIGA}
  119. CDrive = 'C';
  120. {$ELSE HASAMIGA}
  121. CDrive = 'C:';
  122. {$ENDIF HASAMIGA}
  123. {$ENDIF MACOS}
  124. {$ENDIF UNIX}
  125. {$ENDIF FPC}
  126. TestFileName = 'testfile.tst';
  127. TestDir1Name = 'TESTDIR1';
  128. TestDir2Name = 'TESTDIR2';
  129. HasErrors: boolean = false;
  130. {$IFDEF DIRECT}
  131. procedure XToDirect (var S: string);
  132. var
  133. I: byte;
  134. begin
  135. if DirectorySeparator2 <> DirectorySeparator then
  136. for I := 1 to Length (S) do
  137. if S [I] = DirectorySeparator2 then
  138. S [I] := DirectorySeparator;
  139. {$IFNDEF FPC_FEXPAND_DRIVES}
  140. if DriveSeparator = DirectorySeparator then
  141. I := Pos (DirectorySeparator + DirectorySeparator, S)
  142. else
  143. I := Pos (DriveSeparator, S);
  144. if I <> 0 then
  145. Delete (S, 1, I);
  146. {$ENDIF FPC_FEXPAND_DRIVES}
  147. end;
  148. procedure GetDir (Drive: byte; var Directory: string);
  149. begin
  150. System.GetDir (Drive, Directory);
  151. XToDirect (Directory);
  152. end;
  153. {$I fexpand.inc}
  154. {$ENDIF DIRECT}
  155. var
  156. {$IFNDEF NODRIVEC}
  157. CDir,
  158. {$endif}
  159. TestDir, TestDir0, OrigDir, OrigTstDir, CurDir, S: DirStr;
  160. TestDrive: string [2];
  161. I: byte;
  162. IOR: longint;
  163. F: file;
  164. function Translate (S: PathStr): PathStr;
  165. var
  166. I: byte;
  167. begin
  168. {$IFDEF UNIX}
  169. if (Length (S) > 1) and (S [2] = ':') then Delete (S, 1, 2);
  170. {$ELSE UNIX}
  171. for I := 1 to Length (S) do if S [I] = '/' then S [I] := DirSep;
  172. if (Length (S) > 1) and (S [1] in ['a'..'z']) and (S[2]=DriveSep) then
  173. S [1] := UpCase (S [1]);
  174. {$ENDIF UNIX}
  175. if not (FileNameCasePreserving) then
  176. for I := 1 to Length (S) do S [I] := UpCase (S [I]);
  177. Translate := S;
  178. end;
  179. procedure Check (Src, Rslt: PathStr);
  180. var
  181. Rslt2: PathStr;
  182. begin
  183. {$IFDEF DEBUG}
  184. WriteLn (Src, '=>', Rslt);
  185. {$ENDIF DEBUG}
  186. Rslt := Translate (Rslt);
  187. Rslt2 := FExpand (Src);
  188. {$IFDEF DIRECT}
  189. {$IFNDEF FPC_FEXPAND_DRIVES}
  190. I := Pos (System.DriveSeparator, Rslt2);
  191. if I <> 0 then
  192. Delete (Rslt2, 1, I);
  193. {$ENDIF FPC_FEXPAND_DRIVES}
  194. {$ENDIF DIRECT}
  195. {$IFNDEF UNIX}
  196. if (Length (Rslt2) > 1) and (Rslt2 [1] in ['a'..'z']) and (Rslt2[2]=DriveSep) then
  197. Rslt2 [1] := UpCase (Rslt2 [1]);
  198. {$ENDIF NDEF UNIX}
  199. if Rslt <> Rslt2 then
  200. begin
  201. WriteLn ('Error: FExpand (', Src, ') should be "', Rslt, '", not "',
  202. Rslt2, '"');
  203. HasErrors := true;
  204. end;
  205. end;
  206. begin
  207. if ParamCount <> 1 then
  208. begin
  209. WriteLn ('Warning: Parameter missing!');
  210. WriteLn ('Full path to a directory with write access' +
  211. {$IFNDEF UNIX}
  212. {$IFNDEF VOLUMES}
  213. #13#10'(preferably not on a C: drive)' +
  214. {$ENDIF VOLUMES}
  215. {$ENDIF UNIX}
  216. ' expected.');
  217. WriteLn ('Trying to use the current directory instead ' +
  218. {$IFDEF UNIX}
  219. '(not quite ideal).');
  220. {$ELSE UNIX}
  221. '(problems might arise).');
  222. {$ENDIF UNIX}
  223. {$IFDEF DIRECT}System.{$ENDIF DIRECT}GetDir (0, TestDir);
  224. end else TestDir := ParamStr (1);
  225. if TestDir [Length (TestDir)] <> DirectorySeparator2 then
  226. TestDir := TestDir + DirectorySeparator2;
  227. {$IFDEF DIRECT}System.{$ENDIF DIRECT}GetDir (0, OrigDir);
  228. {$IFDEF NODRIVEC}
  229. TestDrive := '';
  230. {$ELSE NODRIVEC}
  231. TestDrive := Copy (TestDir, 1, 2);
  232. GetDir ((Ord (TestDir [1]) and not ($20)) - 64, OrigTstDir);
  233. {$ENDIF NODRIVEC}
  234. {$I-}
  235. MkDir (TestDir + TestDir1Name);
  236. if IOResult <> 0 then ;
  237. MkDir (TestDir + TestDir1Name + DirectorySeparator2 + TestDir2Name);
  238. if IOResult <> 0 then ;
  239. {$I+}
  240. ChDir (TestDir + TestDir1Name + DirectorySeparator2 + TestDir2Name);
  241. {$I-}
  242. TestDir0 := TestDir;
  243. {$IFDEF DIRECT}
  244. XToDirect (TestDir);
  245. {$IFNDEF FPC_FEXPAND_DRIVES}
  246. I := Pos (System.DriveSeparator, TestDir);
  247. if I <> 0 then
  248. Delete (TestDir, 1, I);
  249. {$ENDIF FPC_FEXPAND_DRIVES}
  250. {$ENDIF DIRECT}
  251. Assign (F, TestFileName);
  252. Rewrite (F);
  253. Close (F);
  254. if IOResult <> 0 then ;
  255. {$IFNDEF DIRECT}
  256. Assign (F, FExpand (TestFileName));
  257. {$ENDIF DIRECT}
  258. {$I+}
  259. GetDir (0, CurDir);
  260. Writeln('CurDir is "',CurDir,'"');
  261. {$IFDEF DIRECT}
  262. {$IFNDEF FPC_FEXPAND_DRIVES}
  263. I := Pos (System.DriveSeparator, CurDir);
  264. if I <> 0 then
  265. Delete (CurDir, 1, I);
  266. {$ENDIF FPC_FEXPAND_DRIVES}
  267. {$ENDIF DIRECT}
  268. {$IFNDEF NODRIVEC}
  269. GetDir (3, CDir);
  270. Writeln('GetDir(3,X) gives X="',CurDir,'"');
  271. {$ENDIF NODRIVEC}
  272. Check (' ', CurDir + DirSep + ' ');
  273. {$IFDEF HASAMIGA}
  274. Check ('', CurDir);
  275. {$ELSE HASAMIGA}
  276. Check ('', CurDir + DirSep);
  277. {$ENDIF HASAMIGA}
  278. {$IFDEF MACOS}
  279. Check (':', CurDir + DirSep);
  280. {$ELSE MACOS}
  281. Check ('.', CurDir);
  282. {$ENDIF MACOS}
  283. {$IFNDEF NODRIVEC}
  284. if CDir [Length (CDir)] = DirSep then Check ('c:anything', CDir + 'anything')
  285. else Check ('c:anything', CDir + DirSep + 'anything');
  286. Check (CC + DirSep, CDrive + DirSep);
  287. {$IFDEF NODOTS}
  288. Check ('C:.', 'C:.');
  289. Check (CC + DirSep + '.', CDrive + DirSep + '.');
  290. Check (CC + DirSep + '..', CDrive + DirSep + '..');
  291. {$ELSE NODOTS}
  292. Check ('C:.', CDir);
  293. Check (CC + DirSep + '.', CDrive + DirSep);
  294. Check (CC + DirSep + '..', CDrive + DirSep);
  295. {$ENDIF NODOTS}
  296. Check (CC + DirSep + 'DOS', CDrive + DirSep + 'DOS');
  297. {$IFNDEF NODOTS}
  298. Check (CC + DirSep + '..' + DirSep + 'DOS', CDrive + DirSep + 'DOS');
  299. {$ENDIF NODOTS}
  300. Check (CC + DirSep + 'DOS.', CDrive + DirSep + 'DOS.');
  301. {$IFDEF HASAMIGA} (* This has no effect - AMIGA has NODRIVEC defined... *)
  302. Check (CC + DirSep + 'DOS' + DirSep, CDrive + DirSep);
  303. {$ELSE HASAMIGA}
  304. Check (CC + DirSep + 'DOS' + DirSep, CDrive + DirSep + 'DOS' + DirSep);
  305. {$ENDIF HASAMIGA}
  306. {$IFNDEF NODOTS}
  307. Check (CC + DirSep + 'DOS' + DirSep + '.', CDrive + DirSep + 'DOS');
  308. Check (CC + DirSep + 'DOS' + DirSep + '..', CDrive + DirSep);
  309. Check (CC + DirSep + 'DOS' + DirSep + '..' + DirSep, CDrive + DirSep);
  310. Check (CC + DirSep + 'DOS' + DirSep + 'TEST' + DirSep + '..', CDrive +
  311. DirSep + 'DOS');
  312. Check ('C:' + DirSep + 'DOS' + DirSep + 'TEST' + DirSep + '..' + DirSep,
  313. CDrive + DirSep + 'DOS' + DirSep);
  314. {$ENDIF NODOTS}
  315. {$ENDIF NODRIVEC}
  316. {$IFNDEF MACOS}
  317. {$IFDEF HASAMIGA}
  318. Check (DirSep, TestDir + TestDir1Name);
  319. Check (DirSep + DirSep + TestFileName, TestDir + TestFileName);
  320. Check (DirSep + 'DOS', TestDir + TestDir1Name + DirSep + 'DOS');
  321. {$ELSE HASAMIGA}
  322. Check (DirSep, TestDrive + DirSep);
  323. Check (DirSep + '.', TestDrive + DirSep);
  324. Check (DirSep + '..', TestDrive + DirSep);
  325. Check (DirSep + 'DOS', TestDrive + DirSep + 'DOS');
  326. {$ENDIF HASAMIGA}
  327. {$ENDIF MACOS}
  328. Check ('d', CurDir + DirSep + 'd');
  329. {$IFDEF MACOS}
  330. Check (DirSep + 'd', CurDir + DirSep + 'd');
  331. {$ELSE MACOS}
  332. {$IFNDEF NODOTS}
  333. Check ('.' + DirSep + 'd', CurDir + DirSep + 'd');
  334. {$ENDIF NODOTS}
  335. {$ENDIF MACOS}
  336. Check ('d' + DirSep + TestFileName, CurDir + DirSep + 'd' + DirSep + TestFileName);
  337. Check (' d', CurDir + DirSep + ' d');
  338. Check ('dd', CurDir + DirSep + 'dd');
  339. {$IFDEF MACOS}
  340. Check (DirSep + 'dd' + DirSep + 'dd', CurDir + DirSep + 'dd' + DirSep + 'dd');
  341. Check ('dd' + DirSep + 'dd', 'dd' + DirSep + 'dd');
  342. {$ELSE MACOS}
  343. Check ('dd' + DirSep + 'dd', CurDir + DirSep + 'dd' + DirSep + 'dd');
  344. {$ENDIF MACOS}
  345. Check ('ddd', CurDir + DirSep + 'ddd');
  346. {$IFDEF MACOS}
  347. Check ('dddd' + DirSep + 'eeee.ffff', 'dddd' + DirSep + 'eeee.ffff');
  348. {$ELSE MACOS}
  349. Check ('dddd' + DirSep + 'eeee.ffff', CurDir + DirSep + 'dddd' + DirSep
  350. + 'eeee.ffff');
  351. {$ENDIF MACOS}
  352. Check ('.special', CurDir + DirSep + '.special');
  353. Check ('..special', CurDir + DirSep + '..special');
  354. Check ('special..', CurDir + DirSep + 'special..');
  355. {$IFDEF HASAMIGA}
  356. Check ('special.' + DirSep, CurDir + DirSep + 'special.' + DirSep);
  357. {$ELSE HASAMIGA}
  358. {$IFDEF MACOS}
  359. Check ('special.' + DirSep, 'special.' + DirSep);
  360. {$ELSE MACOS}
  361. Check ('special.' + DirSep, CurDir + DirSep + 'special.' + DirSep);
  362. {$ENDIF MACOS}
  363. {$ENDIF HASAMIGA}
  364. {$IFDEF MACOS}
  365. Check (DirSep + DirSep, TestDir + TestDir1Name + DirSep);
  366. Check (DirSep + DirSep + TestFileName, TestDir + TestDir1Name + DirSep
  367. + TestFileName);
  368. {$ELSE MACOS}
  369. Check (DirSep + '.special', TestDrive + DirSep + '.special');
  370. {$IFNDEF NODOTS}
  371. Check ('..', TestDir + TestDir1Name);
  372. Check ('.' + DirSep + '..', TestDir + TestDir1Name);
  373. Check ('..' + DirSep + '.', TestDir + TestDir1Name);
  374. Check (TestDir + TestDir1Name + DirSep + DirSep + '..' + DirSep, TestDir);
  375. Check (TestDir + TestDir1Name + DirSep + '/' + DirSep + '..' + DirSep, TestDir);
  376. Check (TestDir + TestDir1Name + DirSep + DirSep + DirSep + '..' + DirSep, TestDir);
  377. Check (TestDir + TestDir1Name + DirSep + DirSep + TestDir2Name + DirSep + DirSep + '..',
  378. TestDir + TestDir1Name);
  379. Check (TestDir + TestDir1Name + DirSep + DirSep + TestDir2Name + DirSep + DirSep + '..'
  380. + DirSep + DirSep, TestDir + TestDir1Name + DirSep);
  381. {$ENDIF NODOTS}
  382. {$ENDIF MACOS}
  383. {$IFDEF NETWARE}
  384. Check ('...', TestDir);
  385. {$ELSE NETWARE}
  386. Check ('...', CurDir + DirSep + '...');
  387. {$ENDIF NETWARE}
  388. Check (TestFileName, CurDir + DirSep + TestFileName);
  389. {$IFDEF UNIX}
  390. S := GetEnv ('HOME');
  391. { On m68k netbsd at least, HOME contains a final slash
  392. remove it PM }
  393. if (Length (S) > 1) and (S [Length (S)] = DirSep) then
  394. S:=Copy(S,1,Length(S)-1);
  395. if Length (S) = 0 then
  396. begin
  397. Check ('~', CurDir);
  398. Check ('~' + DirSep + '.', DirSep);
  399. end
  400. else
  401. begin
  402. Check ('~', S);
  403. Check ('~' + DirSep + '.', S);
  404. end;
  405. if (Length (S) > 0) and (S [Length (S)] <> DirSep) then
  406. S := S + DirSep;
  407. Check ('~NobodyWithThisNameShouldEverExist.test/nothing', CurDir + DirSep +
  408. '~NobodyWithThisNameShouldEverExist.test/nothing');
  409. Check ('/tmp/~NoSuchUserAgain', '/tmp/~NoSuchUserAgain');
  410. if Length (S) = 0 then
  411. begin
  412. Check ('~' + DirSep, DirSep);
  413. Check ('~' + DirSep + '.' + DirSep, DirSep);
  414. Check ('~' + DirSep + 'directory' + DirSep + 'another',
  415. DirSep + 'directory' + DirSep + 'another');
  416. end
  417. else
  418. begin
  419. Check ('~' + DirSep, S);
  420. Check ('~' + DirSep + '.' + DirSep, S);
  421. Check ('~' + DirSep + 'directory' + DirSep + 'another',
  422. S + 'directory' + DirSep + 'another');
  423. end;
  424. {$ELSE UNIX}
  425. {$IFNDEF NODRIVEC}
  426. Check (TestDrive + '..', TestDir + TestDir1Name);
  427. Check (TestDrive + '..' + DirSep, TestDir + TestDir1Name + DirSep);
  428. Check (TestDrive + '.' + DirSep + '.', CurDir);
  429. Check (TestDrive + '.' + DirSep + '..', TestDir + TestDir1Name);
  430. {$I-}
  431. (*
  432. { $ ifndef unix }
  433. { avoid a and b drives for
  434. no unix systems to reduce the
  435. probablility of getting an alert message box }
  436. { This should not be needed - unit popuperr should solve this?! TH }
  437. I := 3;
  438. {$else unix} *)
  439. I := 1;
  440. { $ endif unix}
  441. repeat
  442. S := '';
  443. GetDir (I, S);
  444. IOR := IOResult;
  445. if IOR = 0 then Inc (I);
  446. until (I > 26) or (IOR <> 0);
  447. if I <= 26 then
  448. begin
  449. S := Chr (I + 64) + ':ddd';
  450. Check (S, Chr (I + 64) + ':' + DirSep + 'ddd');
  451. end else
  452. WriteLn ('Sorry, cannot test FExpand behaviour for incorrect drives here.');
  453. {$I+}
  454. {$IFDEF FPC}
  455. Check ('d\d/d', CurDir + DirSep + 'd' + DirSep + 'd' + DirSep + 'd');
  456. {$ifdef go32v2}
  457. { for go32v2 target UNC paths are only handled if LFNSupport is true }
  458. { Remark: The previous statement may not be correct, UNC paths were already }
  459. { supported with IBM / Microsoft LAN Manager client on plain DOS before LFN }
  460. { / W95 availability, but that probably doesn't matter for our purposes. }
  461. { See e.g. http://www.drdobbs.com/undocumented-corner/184408984 (TH). }
  462. if not LFNSupport then
  463. writeln('Go32v2 without LFN, no UNC support')
  464. else
  465. {$endif}
  466. begin
  467. { Check UNC style paths }
  468. Check ('\\server\share\directory', '\\server\share\directory');
  469. Check ('\\server\share\directory1\directory2\..',
  470. '\\server\share\directory1');
  471. Check ('\\', '\\');
  472. Check ('\\.', '\\.\');
  473. Check ('\\.\', '\\.\');
  474. Check ('\\.\.', '\\.\.');
  475. Check ('\\.\..', '\\.\..');
  476. Check ('\\.\...', '\\.\...');
  477. Check ('\\.\TEST', '\\.\TEST');
  478. Check ('\\..\', '\\..\');
  479. Check ('\\..\TEST', '\\..\TEST');
  480. Check ('\\..\TEST\.', '\\..\TEST');
  481. Check ('\\..\TEST1\TEST2\..', '\\..\TEST1');
  482. Check ('\\..\TEST\..', '\\..\TEST');
  483. Check ('\\..\TEST\..\..', '\\..\TEST');
  484. end;
  485. {$ENDIF FPC}
  486. {$ENDIF NODRIVEC}
  487. {$ENDIF UNIX}
  488. {$IFDEF VOLUMES}
  489. {$IFDEF HASAMIGA}
  490. Check ('VolName' + DriveSep + 'DIR1', 'VolName' + DriveSep + 'DIR1');
  491. {$ELSE HASAMIGA}
  492. Check ('VolName' + DriveSep + DirSep + 'DIR1', 'VolName' + DriveSep + DirSep + 'DIR1');
  493. {$ENDIF HASAMIGA}
  494. {$IFNDEF NODOTS}
  495. Check ('VolName' + DriveSep + DirSep + 'DIR1' + DirSep + '..', 'VolName' + DriveSep + DirSep);
  496. Check ('VolName' + DriveSep + DirSep + 'DIR1' + DirSep + '..' + DirSep + '..',
  497. 'VolName' + DriveSep + DirSep);
  498. Check ('VolName' + DriveSep + DirSep + '.', 'VolName:' + DirSep);
  499. Check ('VolName' + DriveSep + DirSep + '..', 'VolName:' + DirSep);
  500. Check ('VolName' + DriveSep + DirSep + '..' + DirSep, 'VolName' + DriveSep + DirSep);
  501. {$ENDIF NODOTS}
  502. {$IFDEF NETWARE}
  503. Check ('SrvName\VolName' + DriveSep + DirSep + 'TEST', 'SrvName' + DirSep + 'VolName' +
  504. DriveSep + DirSep + 'TEST');
  505. Check ('SrvName/VolName' + DriveSep + DirSep + 'TEST', 'SrvName' + DirSep + 'VolName' +
  506. DriveSep + DirSep + 'TEST');
  507. {$ENDIF NETWARE}
  508. {$IFDEF HASAMIGA}
  509. {$IFDEF NODOTS}
  510. Check ('.', CurDir + DirSep + '.');
  511. {$ELSE NODOTS}
  512. Check ('.', CurDir);
  513. {$ENDIF NODOTS}
  514. {$ENDIF HASAMIGA}
  515. {$ENDIF VOLUMES}
  516. Erase (F);
  517. {$IFNDEF NODRIVEC}
  518. ChDir (OrigTstDir);
  519. {$ENDIF NODRIVEC}
  520. ChDir (OrigDir);
  521. RmDir (TestDir0 + TestDir1Name + DirectorySeparator2 + TestDir2Name);
  522. RmDir (TestDir0 + TestDir1Name);
  523. if HasErrors then
  524. begin
  525. WriteLn ('FExpand doesn''t work correctly.');
  526. Halt (1);
  527. end;
  528. end.