home *** CD-ROM | disk | FTP | other *** search
/ Monster Media 1994 #1 / monster.zip / monster / PCBOARD / ULP106.ZIP / ULP.DOC < prev    next >
Text File  |  1994-01-28  |  99KB  |  1,781 lines

  1.  
  2.     ┌───────────────────┐
  3.     │                   │ ║                UpLoadProcessor
  4.     │    ╥   ╥ ╥        │ ║
  5.     │    ║   ║ ║ ╓──╖   │ ║                 Version 1.06
  6.     │    ║   ║ ║ ║  ║   │ ║
  7.     │    ╙───╜ ╨ ║──╜   │ ║     (c) Copyright 1992-1993 - Stacy Smith
  8.     │            ╨      │ ║
  9.     └───────────────────┘ ║
  10.       ════════════════════╝
  11.  
  12.                                 Courtesy of:
  13.  
  14.                         The Bloom Beacon-Picayune BBS
  15.           Node 1: (919) 557-3845 (USRobotics Courier Dual Standard)
  16.              Node 2: (919) 557-0645 (USRobotics Courier V.32bis)
  17.              Node 3: (919) 557-0745 (USRobotics Courier V.32bis)
  18.                              FidoNet 1:151/106
  19.                                   Intelec
  20.                                  CompuLink
  21.  
  22.                                 Stacy Smith
  23.                             305 Cottonwood Lane
  24.                           Holly Springs, NC 27540
  25.  
  26.  
  27. ┌───────────────────┐
  28. │  1. Introduction  │
  29. └───────────────────┘
  30.  
  31. This system was born out of a need for a universal upload processor. There are
  32. many alternative systems available, but they are limited to the ZIP format and
  33. perhaps one or two others. Few are able to handle self-extracting archives.
  34. Most are limited in the number of levels of archive nesting allowed in a file
  35. to be tested. All require the use of a third-party duplicate file checking
  36. system if you want to screen your uploads for duplicates.
  37.  
  38. Tired of waiting for PKZIP 2.something-or-another, I converted my BBS files
  39. over to the ARJ compression format, due to its superior compression ratio over
  40. PKZip and its features over LHA. I do not intend to debate the merits of one
  41. archive format over another, but due to my decision, the need for a universal
  42. upload processor became apparent, so off I went.
  43.  
  44. While I was at it, I decided to incorporate other technologies, such as
  45. duplicate checking, archive format conversion, information lines, support for
  46. internal description files, etc., into a single package. This software is the
  47. result of my efforts to allow my BBS to handle any archive that my users can
  48. throw at it.
  49.  
  50.  
  51. ┌─────────────────────────────────────────────┐
  52. │  2. Features of the UpLoadProcessor System  │
  53. └─────────────────────────────────────────────┘
  54.  
  55.   ∙ Identifies and processes ARC, ARJ, HYP, LZH, PAK, SQZ, ZIP, ZOO and GIF
  56.     files, regardless of their file extensions (ideal for software distribution
  57.     network files, e.g. SDN).
  58.   ∙ Identifies and processes ARJ, LZH, PAK, SQZ and ZIP self-extracting (SFX)
  59.     archives.
  60.   ∙ Scans ARC, PAK, ZIP and ZIP SFX archives for DOS reserved keywords to
  61.     prevent hacking by hex-editing. (ARJ and LHA are resistant to these type of
  62.     hacking attempts).
  63.   ∙ Detects ARJ security envelopes and ZIP version 1.x and 2.x authenticity
  64.     verification (-AV) stamps and may be retained intact.
  65.   ∙ Detects and processes ARJ and ZIP archives with imbedded paths.
  66.   ∙ Detects and rejects encrypted ARJ and ZIP archives.
  67.   ∙ Selected uncompressed files uploaded can be processed and compressed using
  68.     your default format.
  69.   ∙ Removes known BBS ads from archives; includes a BBS ads maintenance utility
  70.     so sysops can update their BBS ads databases in real time. ULP can also
  71.     insert a BBS ad, if desired.
  72.   ∙ Updates the PCBoard DOWNLOAD.TXT file, if desired, with the correct archive
  73.     extension to reflect the conversion process.
  74.   ∙ Allows the use of up to 9 different archiving programs, all user-
  75.     configurable. Any archiving program used that is not listed above will be
  76.     identified using it's unique file extension only, until it's signature is
  77.     determined and incorporated into the program.
  78.   ∙ Uses a recursive processing routine that will allow (theoretically)
  79.     unlimited nested archives (the only limit is imposed by the DOS path). This
  80.     routine has been tested to 5 levels deep as of this writing.
  81.   ∙ Allows the use of up to 3 different file-checking programs, all user-
  82.     configurable, for virus and trojan checking, third-party utilities, etc.
  83.   ∙ Allows the use of a GIF file checking program, completely configurable.
  84.   ∙ Rejects GIF files based upon image width, height, colors and compression.
  85.   ∙ User-definable disposition (rename or delete) of corrupted, duplicate or
  86.     other archives (not virus-related).
  87.   ∙ User-definable disposition (rename or delete) of virus-infected archives.
  88.   ∙ Incorporates it's own duplicate checking system, as well as the associated
  89.     database processing software. No more executing (and registering!)
  90.     third-party duplication checking software, sacrificing speed and memory.
  91.     This system is extremely fast and it's database is much smaller than other
  92.     systems. Despite it's size, the probability of a false duplication is
  93.     almost 1 in 10 trillion! The system is self-validating, to quickly
  94.     determine if a database has been corrupted or altered.
  95.   ∙ Optional seamless interface with the ZDCS duplication system by Mike Cocke.
  96.   ∙ ULP determines duplication using two filters, total duplication and
  97.     executable duplication, preventing false rejection by simply counting up
  98.     the number of blatantly duplicate files.
  99.   ∙ Converts all uploads into a default archive format of your choosing, or
  100.     they may be re-archived in their original format (user-defined). Nested
  101.     archives can also be converted to your default format, or re-archived using
  102.     their original format. SFX archives can be archived using your default
  103.     format, or optionally left alone after verification.
  104.   ∙ Can utilize a user-defined time window (in months) for acceptance of new
  105.     upload files, based on the average age of the files within the archive, or
  106.     optionally, the age of the newest file.
  107.   ∙ Changes all archive file attributes to 'read/write' from 'read-only'.
  108.   ∙ Supports the use of private and public upload directories. Moves files and
  109.     upload descriptions from the private directory to the public directory.
  110.     Single directory operation may also be configured.
  111.   ∙ Honors the '/' identifier in the description marking the file as a private
  112.     upload for the sysop by processing the file, but not making it public.
  113.   ∙ Supports the use of DESC.SDI and FILE-ID.DIZ description files in an
  114.     archive, user-configurable, for those not running PCBoard 14.5a+ and
  115.     PCBDESC.
  116.   ∙ Smart word-wrapping word-wraps descriptions or leaves them as entered,
  117.     depending upon the presence of boxes, etc.
  118.   ∙ Can optionally insert an archive or GIF information line in the file
  119.     description that contains various information about the archive or GIF
  120.     files.
  121.   ∙ Three modes of online testing are available: slow mode, which completely
  122.     processes files at the time of upload; normal mode, which fully unpacks the
  123.     archive and tests each file individually; and fast mode, which scans a ZIP
  124.     or ARJ archive directly for file CRCs, sizes and dates, and uses the
  125.     archiving program's internal integrity testing.
  126.   ∙ The online tester will accept a redirected ARJ or PKUNZIP archive listing
  127.     file to pre-verify the duplication and age limits before a user uploads the
  128.     actual archive, saving him or her wailing and gnashing of teeth.
  129.   ∙ ULPTEST can generate COM port status output to inform the online user of
  130.     the progress of testing. ULPTEST supports IRQs 2 through 7, non-standard
  131.     port addresses and baud rates to 115K in direct mode, and also supports
  132.     FOSSIL drivers. The port information can be defined on the command-line or
  133.     can be read directly from PCBOARD.DAT and PCBOARD.SYS. ULP can also be
  134.     implemented in a "seamless" mode (when registered) to look like a part of
  135.     PCBoard.
  136.   ∙ Import of FWKCS(TM) contents_signature databases is supported to ease
  137.     transition to the ULP duplication system. No need to rebuild databases for
  138.     FWKCS users!
  139.   ∙ Archives failed for exceeding duplication limits can be viewed using ULPDB
  140.     (the database program), to allow easy determination of manual archive
  141.     acceptance.
  142.   ∙ User-selectable process logging to a disk file. Two logging modes are
  143.     available: terse and verbose.
  144.   ∙ Menu-driven windowed system manager for maximum ease of configuration.
  145.   ∙ Written mostly in C (and a little assembler) for optimal speed, using
  146.     Microsoft C 7.0, Borland C++ 3.1 and Turbo Assembler 3.0.
  147.  
  148.  
  149. ┌─────────────────────────────────────────────────────┐
  150. │  3. Files Included in the ULP Distribution Archive  │
  151. └─────────────────────────────────────────────────────┘
  152.  
  153.     ULP.EXE         Event upload processing program.
  154.     ULPTEST.EXE     On-line testing program for use in PCBTEST.BAT.
  155.     ULPDB.EXE       Duplication database creation and maintenance program.
  156.     ULPSM.EXE       System and configuration manager for the ULP system.
  157.     ULPADS.EXE      BBS ads database maintenance program.
  158.     ULPADS.DB       BBS ads database file.
  159.     ULP.CFG         Sample configuration file for the ULP system.
  160.     ULPDIR.CFG      Sample directory configuration file.
  161.     UPDATE.EXE      Configuration file conversion utility (if necessary).
  162.     EXCLUDE.LST     Sample exclusion list for archivers.
  163.     PCBTEST.BAT     Sample PCBTEST.BAT file for using ULPTEST.
  164.     ULP.DOC         This file.
  165.     Q&A.DOC         Answers to common questions regarding the ULP system.
  166.     HISTORY.TXT     ULP revision history in reverse order.
  167.     ULPBLT          Archive verification bulletin for sysops to post.
  168.     REGISTER.FRM    Registration form for ULP.
  169.     COMMENT.TXT     Sample comment file for inclusion in archive headers.
  170.     FILE_ID.DIZ     Internal description file.
  171.  
  172. When you unzip the distribution archive, you should see my PKZIP authenticity
  173. verification stamp, and a '-AV' after every file in the archive:
  174.  
  175.     # SSU301    The Bloom Beacon-Picayune BBS
  176.  
  177. If there are any files missing or added, or the -AV stamp is missing, the
  178. archive has been tampered with. It would be advisable to call my BBS (listed at
  179. the top of this document) for the latest version of ULP.
  180.  
  181.  
  182. ┌───────────────────────────┐
  183. │  4. Program Requirements  │
  184. └───────────────────────────┘
  185.  
  186. To the best of my knowledge, this program will run on most any machine capable
  187. of running PCBoard 14.5+. My BBS setup is DESQview on a LANtastic network with
  188. hard disks and CD-ROMs, but other sysops that I have been in contact with have
  189. successfully implemented ULP on setups other varying hardware and software.
  190.  
  191. ULP has been developed and tested using the following third party utilities:
  192.  
  193.     ARJ 2.10 and higher (by Robert Jung)
  194.     HYPER 2.5 (by P. Sawatzki and K. P. Nischke)
  195.     LHA 2.12 and higher (by Haruyasu Yoshizaki)
  196.     LHarc 1.13c (by Haruyasu Yoshizaki)
  197.     PAK 2.51 (by NoGate Consulting)
  198.     PKPAK 3.61 (by PKWare)
  199.     PKZIP 1.10 and higher (by PKWare)
  200.     SQZ 1.08.2 (by Jonas Hammarberg)
  201.     ZOO 2.01 and higher (by Rahul Deshi)
  202.     AntiAd 0.98ß and higher (by Stacy Smith)
  203.     F-PROT 2.07 and higher (by Frisk Software International)
  204.     SCAN V82 and higher (by McAfee Associates)
  205.     GIFTEST 4.0 Beta 10 and higher (by Dave Navarro)
  206.     ZDCS 2.02 (by Mike Cocke)
  207.     SHROOM 2.3a (by Davis Augustine)
  208.  
  209. The ULP system requires DOS 3.x or later, as it uses DOS SHARE-compatible file
  210. reads and writes, and can use the DOS PATH to find the archiving and other
  211. utilities.
  212.  
  213. ULP and ULPTEST's memory requirements are relatively small (about 110K or so
  214. with data buffers allocated), but all programs are spawned or shelled, which
  215. reduces the free memory for the program being executed. It would be a good idea
  216. to have as much free conventional memory as possible (ULP itself cannot use EMS
  217. or XMS memory), especially if you use the ARJ compression system, which
  218. requires in the neighborhood of 300K itself to run.
  219.  
  220. ULPDB also should have as much conventional memory as can be afforded, as it
  221. performs its sort in memory for optimal speed; it may use from 120K to 575K of
  222. memory depending upon the operation being performed. If your duplication
  223. database is larger than 500K (over 50,000 file entries), ULPDB may utilize a
  224. segmented sort algorithm, which is slower but capable of completely compiling a
  225. database up to 128MB in size (almost 13,000,000 file entries)! The memory sort
  226. will probably be fine for many systems, as 50,000 files would probably average
  227. out to be about 4,000 to 5,000 typical archives.
  228.  
  229. Obviously, the 286+ and 386+ versions of these programs that is available to
  230. registered users will not run on a 8088, 8086 or 80186 (huh?) based computer.
  231. So don't try it (I haven't, so I don't have a clue what will happen...probably
  232. spontaneous combustion...).
  233.  
  234.  
  235. ┌───────────────────┐
  236. │  5. Registration  │
  237. └───────────────────┘
  238.  
  239. The ULP system is not free; nor is ULP is crippled to force registration. ULP
  240. is fully functional, and will always remain so. The only variation with the
  241. registered copies is no time delay and beg message.
  242.  
  243. Why register? Besides a clean conscience, you will get a registration code that
  244. will work for all future versions of ULP, and will remove the delay and message
  245. at the end of execution of each program. In addition, registration will allow
  246. you to run ULPTEST in a "seamless" mode so that it looks like a part of
  247. PCBoard to the user.
  248.  
  249. In addition, the registation code will allow use of the 286 or 386 specific
  250. versions of ULP that are made available only to registered users of ULP. These
  251. versions are slightly smaller and faster than the shareware 086+ version.
  252.  
  253. The registration fee for your unique code is $20 for non-commercial BBSes. The
  254. registration fee for commercial BBSes, defined as running your BBS in the
  255. course of a commercial business or for profit, is $40. Other variations are
  256. available; refer to the file REGISTER.FRM for all registration options. Please
  257. print the file REGISTER.FRM and fill it out. You can print out the form by
  258. issuing the following command from the DOS prompt:
  259.  
  260.     TYPE REGISTER.FRM > PRN
  261.  
  262.  
  263. ┌───────────────────────────────────────┐
  264. │  6. License, Warranty and Disclaimer  │
  265. └───────────────────────────────────────┘
  266.  
  267. I'll keep this part short and sweet, and dispense with the legal-ese:
  268.  
  269.     License: You are allowed to use ULP for 30 days, after which you must
  270.         either register ULP or stop using it completely. ULP registration is a
  271.         license for your use of ULP; I retain ownership of the software. A
  272.         single registration applies to a single BBS system, regardless of the
  273.         number of computers used in the system. If you run two or more distinct
  274.         BBS systems on the same computer or network (with different names), you
  275.         require two or more ULP registrations. Refer to the registration form
  276.         for the currect pricing structure.
  277.  
  278.     Warranty: There isn't one. The only thing I'll guarantee is that ULP will
  279.         take up disk space, and will disappear when deleted.
  280.  
  281.     Disclaimer: I'm not responsible for anything bad that happens. ULP works
  282.         here, but I cannot be held responsible for it not working on your
  283.         computer or doing any damage to hardware or software.
  284.  
  285. If these aren't agreeable with you, then the best thing to do is delete ULP
  286. right now. I'll do my best to help any user (registered or not) that wants to
  287. use ULP, and I'll act on bug reports quickly, but I simply cannot and will not
  288. be responsible for anything bad, like lost data, disk crashes, or whatever
  289. else you can think of.
  290.  
  291.  
  292. ┌────────────────────────────┐
  293. │  7. Conceptual Background  │
  294. └────────────────────────────┘
  295.  
  296. Since the ULP system is made up of several inter-operating programs, this
  297. overview and concept explanation should help you understand how ULP is
  298. designed to be used.
  299.  
  300. *******************************************************************************
  301.      READ THIS SECTION VERY CAREFULLY, AS IT WILL MAKE LIFE MUCH EASIER!!!
  302. *******************************************************************************
  303.  
  304. I believe that all responsible BBS sysops verify all of their uploads prior to
  305. posting them, in order to protect both themselves and their users. ULP is
  306. designed with idea in mind. Most, if not all, sysops process uploads in one of
  307. two ways (listed with benefits and liabilities as I see them):
  308.  
  309.     1) Make all uploads private, processing them during a system event.
  310.  
  311.        BENEFITS:
  312.            ∙ Takes up very little on-line time on the user's part to process
  313.              archives.
  314.            ∙ Allows the conversion of all archives to a default format, so that
  315.              the BBS archives are consistent.
  316.            ∙ Allows the BBS to accept any archive format...face it, it's hard
  317.              enough to get some of these weenies to upload, much less compress
  318.              them the same way.
  319.  
  320.        LIABILITIES:
  321.            ∙ Files are not available immediately for download.
  322.            ∙ The 'U' subcommand of PCBoard's (F)ile Directories command is no
  323.              longer available to the user (PCBoard 14.5a and below).
  324.            ∙ Does not catch duplicates or aged archives until after the user
  325.              has uploaded them, and perhaps leads to abuse by clever (?) users.
  326.              (It is assumed that these sysops still use the venerable 'PKUNZIP
  327.              -T' in their PCBTEST.BAT...)
  328.  
  329.     2) Process (test) each upload online after the user uploads them, and
  330.        making them available for immediate download.
  331.  
  332.        BENEFITS:
  333.            ∙ Catches duplicate, defective and aged archives while the user is
  334.              online, denying him upload credits.
  335.            ∙ Files are available immediately for download if they are not made
  336.              private in the PCBoard setup.
  337.  
  338.        LIABILITIES:
  339.            ∙ Takes up on-line time for a user, potentially adding to his
  340.              long-distance phone bill, discouraging further uploading; this
  341.              process is typically quite slow for large archives.
  342.            ∙ The archive format cannot be converted (a limitation of PCBoard),
  343.              leaving many different archive formats in your BBS directories.
  344.              Because of this, many sysops force users to use a specific format,
  345.              which may or may not be consistent with other BBS's the user
  346.              calls.
  347.  
  348. The ULP system takes the best of both of these methods of testing. ULP.EXE is
  349. an event-mode processor which will fully process every new archive found in the
  350. source upload directory, including archive format conversion, and optionally
  351. move the file and description to a destination directory. In the simplest
  352. ULP system setup, you MUST run ULP.EXE in your event to completely process all
  353. uploads to your system.
  354.  
  355. ULPTEST.EXE is an online processor, with a varying modes of operation, from
  356. complete processing to a very fast scan of the archive directly for data. These
  357. modes will allow you to run your BBS in the most efficient manner. Note that
  358. the conversion process MUST be handled by ULP during the system event, due to
  359. the design of PCBoard.
  360.  
  361. Pay attention to this part:
  362.  
  363. PCBoard normally has two upload directories for each conference: a private and
  364. a public directory. When PCBoard invokes PCBTEST.BAT, the upload is in the
  365. private directory. If the archive fails the testing, it will remain there.
  366. However, if it passes, one of two things will occur depending upon your system
  367. setup; if you have made all uploads private, the file will remain in the
  368. private directory; if you have not made uploads private, it will be moved BY
  369. PCBOARD (not ULPTEST) to the public directory.
  370.  
  371. If you have made all uploads private, then setup and configuration of ULP is a
  372. snap: the source directory is the private upload directory, and the destination
  373. is the public directory. However, if you want to allow users access to untested
  374. uploads, then your source directory is the public upload directory, and the
  375. destination information is left blank. To illustrate the operation:
  376.  
  377.   MAKE ALL UPLOADS PRIVATE           │  ALL UPLOADS AVAILABLE AFTER TESTING
  378.   ───────────────────────────────────┼─────────────────────────────────────
  379.   2 directories:  C:\PRIVATE         │  2 directories:  C:\PRIVATE
  380.                   C:\PUBLIC          │                  C:\PUBLIC
  381.                                      │
  382.   User uploads a file, gets placed   │  User uploads a file, gets placed
  383.   in C:\PRIVATE by PCBoard           │  in C:\PRIVATE by PCBoard
  384.                                      │
  385.   ULPTEST.EXE tests it               │  ULPTEST.EXE tests it
  386.                                      │
  387.   PCBoard leaves file in C:\PRIVATE  │  If it passes, PCBoard moves it to
  388.                                      │  C:\PUBLIC; if it fails, PCBoard
  389.                                      │  leaves it in C:\PRIVATE
  390.                                      │
  391.   ULP.EXE processes all new uploads  │  ULP.EXE processes all *new* uploads
  392.   found in C:\PRIVATE since last     │  found in C:\PUBLIC since last event
  393.   event and moves all good uploads   │
  394.   to C:\PUBLIC                       │
  395.  
  396. ULPTEST.EXE also has three modes of operation: slow, normal and fast. Slow mode
  397. completely tests the upload as in the event, except for archive conversion.
  398. Note that you MUST use the "all uploads public" mode of operation to run slow
  399. mode.
  400.  
  401. The normal mode decompresses the files, performs file, duplication and age
  402. checking, and then deletes the extracted files and returns to PCBoard,
  403. informing PCBoard of the test results. It does not recompress the archive,
  404. remove BBS ads, add information lines, etc.; this is saved for the event
  405. processing. This mode can be used with both setup paradigms, making all uploads
  406. private or public.
  407.  
  408. Fast mode DOES NOT decompress the file; it firsts performs an archive integrity
  409. check, then scans ARJ and ZIP archives directly for duplicate and age
  410. information, and then returns to PCBoard (if the archive is not ARJ or ZIP,
  411. then normal mode is forced). In fast mode, file checking (viruses, etc.) is
  412. left for ULP to do (which is why the above discussion regarding private/public
  413. directories is important). This mode can also be used either in making uploads
  414. public or private, although it would be a good idea to make them private with
  415. this mode, since the uploads are not file-checked (e.g. viruses) during
  416. test.
  417.  
  418. ULPTEST.EXE will also accept a redirected ARJ or PKUNZIP listing text file with
  419. the special name VERIFY.ULP as input to pre-verify an upload for a user, before
  420. the user actually spends his time uploading the file only to find out it won't
  421. pass the limits you set.
  422.  
  423.  
  424. ┌───────────────────┐
  425. │  8. Installation  │
  426. └───────────────────┘
  427.  
  428. GENERAL (REQUIRED!):
  429. ───────────────────
  430. Make a subdirectory on your hard drive. For the purposes of this document,
  431. we'll call it "C:\ULP". Unarchive the ULP distribution archive into this
  432. subdirectory. You've more than likely already made it this far, if you're
  433. reading this file. <g>
  434.  
  435. The ULP system opens several files at once for various reasons. I would
  436. recommend that you have a minimum of FILES=30 per node in your system
  437. CONFIG.SYS file, since ULPTEST is run in conjunction with PCBoard.
  438.  
  439. If you are running PCBoard under a network or a multitasking operating system,
  440. you should already have DOS's SHARE.EXE loaded. You must have SHARE loaded in
  441. order to take advantage of the file sharing and locking methods used by the ULP
  442. programs to prevent data loss. (If you are running a single-node system without
  443. a multitasker, SHARE is not needed).
  444.  
  445. * NOTE: DOS 5 has a documented bug when SHARE is loaded high, where it loses
  446.     the table in memory. Please load SHARE low to prevent potential sharing
  447.     problems.
  448.  
  449. Using ULPSM, configure the ULP system to suit your needs. Proper configuration
  450. will require you to refer to this section, the previous section and the section
  451. titled "Configuration", which has an in-depth explanation of each configuration
  452. option and its function. It would probably be wise to fire up your printer for
  453. this document.
  454.  
  455. For this document, we'll assume the name of your configuration file is
  456. "ULP.CFG".
  457.  
  458. Note that for any of the ULP programs, you can obtain a limited program syntax
  459. screen simply by executing the program with no arguments.
  460.  
  461. FOR EVENT-MODE UPLOAD PROCESSING (REQUIRED!):
  462. ────────────────────────────────────────────
  463. As a minimum setup, you MUST run ULP as an event-mode processor, as ULP.EXE
  464. handles most of the database updating, archive conversion, file and description
  465. moving, archive information line computation, and other features. THIS IS NOT
  466. AN OPTION!!!
  467.  
  468. Further, ULP requires that you define the upload disk directories and upload
  469. DIRxx files. They can be either a private/public setup or public setup, as
  470. described below (and in the 'principles of operation' section):
  471.  
  472.   - PRIVATE/PUBLIC SETUP:  This setup will not allow users to get to any
  473.     archive that has not been fully processed. In PCBSETUP, under Main Board
  474.     Configuration (and any other conferences you want ULP to process), make all
  475.     uploads private. Define a private upload directory and a private DIRxx file
  476.     (which should have already been done, since all sysop-only uploads are
  477.     placed here by PCBoard). In PCBSETUP, be sure to set the "make all uploads
  478.     private" flag to "Y". This is how I have my system setup.
  479.  
  480.   - PUBLIC SETUP:  This setup will allow users to download archives from the
  481.     public upload directory, including partially testing archives. In PCBSETUP,
  482.     under Main Board Configuration (and any other conferences you want ULP to
  483.     process), define a private upload directory and a private DIRxx file, and a
  484.     public upload directory and a public DIRxx file (this is where PCBoard will
  485.     place all new non-private uploads since you did not make them private). Be
  486.     sure to set the "make all uploads private" flag to "N".
  487.  
  488. To process your uploads during your system event, add the following lines to
  489. your EVENT.SYS file (be sure to change the drive and path as necessary):
  490.  
  491.     C:
  492.     CD \ULP
  493.     ULP -CULP.CFG
  494.  
  495. ULP will lock the duplication database, preventing any other program from
  496. accessing them (ULPTEST and ULPDB, specifically). Therefore, I strongly suggest
  497. you have all nodes down when running ULP.EXE, or at least disable uploading
  498. during this time.
  499.  
  500. Once you have ULP configured, before you run ULP for the first time, the
  501. process data file must be initialized (either via ULPSM or using ULP.EXE's -I
  502. parameter). The syntax for ULP.EXE is as follows, but please refer to the
  503. manual operation section below for more information:
  504.  
  505.     ULP -CULP.CFG -I
  506.  
  507. This is only done ONCE, and never needs to be done again; ULP maintains this
  508. file as a course of action during normal operation.
  509.  
  510. FOR THE INTEGRATED DUPLICATION SYSTEM (HIGHLY RECOMMENDED):
  511. ───────────────────────────────────────────────────────────
  512. Initially, you must create the duplication database from scratch. If you have
  513. mostly ZIP and ARJ files, then this should be very quick (on the order of 10
  514. minutes per 1000 archives for my 10MHz AT clone on a hard disk; a CD-ROM will
  515. be somewhat slower). After you configure ULP, go to the ULP directory and this
  516. command will create and compile your database of your current downloadable file
  517. base:
  518.  
  519.     ULPDB -CULP.CFG -A@C:\PCB\GEN\DLPATH.LST -S
  520.  
  521. The '@' symbol (a '!' may also be used) indicates to ULPDB that the argument is
  522. a list file, not a directory. The list file must have one path per line, and
  523. each path must end with a trailing backslash. In general, you may simply use
  524. your PCBoard DLPATH.LST file, unless you index your downloads.
  525.  
  526. If you would like to include any off-line files in your duplication database
  527. (or have to add files originally not included in the database) you can
  528. temporarily copy your offline files to a temp directory (for the sake of
  529. argumentation, let's call it "C:\TEMP\"; note the trailing backslash). You can
  530. then add and compile them into the duplication database with the following
  531. command (no list symbol!):
  532.  
  533.     ULPDB -CULP.CFG -AC:\TEMP\ -S
  534.  
  535. After you've added the offline files, just delete them from the disk, and if
  536. someone uploads a file that you already have, it will be rejected.
  537.  
  538. * NOTE: The default method of database generation will be the fastest mode
  539.     since ULPDB will scan ARJ and ZIP archives for data without unpacking. This
  540.     is not as accurate as recursively unpacking the archives since ULPDB can
  541.     only 'see' one level deep into an archive; nested information will not be
  542.     obtained. If this poses a problem, add the -U parameter to the end of the
  543.     command lines above; this will force ULPDB to unpack all archives and
  544.     compute the CRCs. This will be significantly slower than the default
  545.     method, but 100% accurate.
  546.  
  547. If you already have a FWKCS duplication database, you can import and translate
  548. it into the ULP database by using the -I command line parameter. ULPDB will
  549. prompt you for which database format it is, and will then proceed to import it
  550. into the ULP database defined in ULP.CFG:
  551.  
  552.     ULPDB -CULP.CFG -IC:\FWKCS\CSLIST -S
  553.  
  554. Once you have your database built, you should also perform maintenance on the
  555. duplication database files regularly. This will compile any new data from the
  556. day's uploads into the main database, and remove any added temporary data from
  557. ULPTEST. This is not required to be done every day, but it will speed the
  558. duplicate checking of ULP and ULPTEST. To perform database maintenance, add the
  559. following line to your PCBoard EVENT.SYS after the event-mode processor has
  560. run:
  561.  
  562.     C:                    ──────┐        These lines are repeated
  563.     CD \ULP                     ├─────   for clarity.
  564.     ULP -CULP.CFG         ──────┘
  565.     ULPDB -CULP.CFG -S
  566.  
  567. ULPDB also locks the duplication database, preventing any other program from
  568. accessing them. I strongly suggest you have all nodes down when running ULPDB.
  569.  
  570. IF YOU USE PCBOARD'S 'TESTFILE.EXE' UTILITY:
  571. ────────────────────────────────────────────
  572. * NOTE: If you are unfamiliar with the operation of PCBTEST.BAT, you will need
  573.     to refer to the PCBoard manual for an explanation of PCBTEST.BAT and
  574.     TESTFILE.EXE.
  575.  
  576. In general, the use of TESTFILE.EXE is not necessary with ULPTEST. ULPTEST is
  577. fully capable of handling most any situation that arises. However, if you must
  578. use TESTFILE.EXE for some reason, in order to take advantage of the upload
  579. pre-verification abilities of ULPTEST, you must add the extension 'ULP' to the
  580. TESTFILE.EXE extension list. This will allow the file 'VERIFY.ULP' to pass
  581. through the filter created by TESTFILE so that ULPTEST may scan it. You will
  582. also have to add 'EXE' to your extension list if you use TESTFILE.EXE, to allow
  583. SFX archives to be processed by ULPTEST.
  584.  
  585. FOR THE ONLINE UPLOAD TESTING (OPTIONAL):
  586. ─────────────────────────────────────────
  587. Online testing of archives can greatly reduce the amount of garbage your BBS
  588. can pick up from user's uploading defective archives, ancient files, and
  589. duplicates. The theory that ULPTEST uses is to simply check the archive AS
  590. FAST AS IT CAN for archive integrity, duplication, and age, and then return
  591. the user to greater and better things. ULP.EXE will handle everything else
  592. during the system event.
  593.  
  594. * NOTE: In order to use ULPTEST, you must set PCBoard to swap by adding the
  595.     /SWAP switch to the SET PCB= environment variable in BOARD.BAT (in PCBoard
  596.     15.0, this is in PCBSETUP, not the environment variable). Otherwise, there
  597.     will not be enough memory for ULPTEST to execute programs like ARJ, SCAN,
  598.     etc.
  599.  
  600. To use ULPTEST.EXE for on-line testing of archives, use the following command
  601. line in PCBTEST.BAT (refer to the sample PCBTEST.BAT included in the ULP
  602. distribution archive, and the PCBoard manual, to get the general logic of
  603. PCBTEST.BAT's operation). Note the explicit paths to the ULPTEST executable and
  604. the ULP configuration file:
  605.  
  606.     C:\ULP\ULPTEST -CC:\ULP\ULP.CFG -F%1 -M%2 -D%3
  607.  
  608. ULPTEST will garner any other information that is required for operation from
  609. the PCBOARD.DAT and PCBOARD.SYS files. In most installations, ULPTEST will
  610. locate these two system files via the environment variables PCBDAT, PCBDRIVE
  611. and PCBDIR. If the environment variables are used, PCBDIR and PCBDAT are
  612. required; PCBDRIVE is required only if the BBS drop files exist on a different
  613. drive than PCBTEST.BAT is being executed from.
  614.  
  615. * NOTE: Don't rely on PCBoard to create these variables; it only does so prior
  616.     to executing a door. As a last resort, ULPTEST will look in the current
  617.     directory for the files it requires.
  618.  
  619. If you have the environment variables disabled in PCBoard (using the /NOENV
  620. switch), you can define the location of these files by adding the -P parameter:
  621.  
  622.     C:\ULP\ULPTEST -CC:\ULP\ULP.CFG -F%1 -M%2 -D%3 -PC:\PCB\NODE1\
  623.  
  624. Or, or you can provide the port and node number information directly to ULPTEST
  625. by using the -N, -I, -A and -B command switches:
  626.  
  627.     C:\ULP\ULPTEST -CC:\ULP\ULP.CFG -F%1 -M%2 -D%3 -N5 -I4 -A3F8 -B38400
  628.  
  629. where -N is the node number, -I is the port IRQ line, -A is the port base
  630. address (in hex) and -B is the baud rate of the port. If you are using the
  631. DSZPORT environment variable to define the port IRQ and address to DSZ, ULPTEST
  632. will use this information as well. Refer to the documentation for DSZ for the
  633. proper specification of the DSZPORT environment variable.
  634.  
  635. In addition, regardless of the method used to inform ULPTEST of the port
  636. information, ULPTEST defaults to using hardware handshaking. If you want to use
  637. software (XON/XOFF) handshaking or both, use the -H command switch with either
  638. HARDWARE, SOFTWARE or BOTH as the argument:
  639.  
  640.     C:\ULP\ULPTEST -CC:\ULP\ULP.CFG -F%1 -M%2 -D%3 -Hboth
  641.  
  642. ULPTEST is also capable of using a FOSSIL driver, and automatically detects if
  643. you are running PCBoard /M and uses the appropriate FOSSIL port. However, if
  644. you wish to force ULPTEST to use a FOSSIL driver (for example, to access high
  645. IRQs), use the -X command switch with the FOSSIL port number as the argument:
  646.  
  647.     C:\ULP\ULPTEST -CC:\ULP\ULP.CFG -F%1 -M%2 -D%3 -X1
  648.  
  649. During the course of testing, ULPTEST will output the current testing status to
  650. the user online. Note that this information is not displayed locally; it is
  651. being transmitted to the online user only. The program header can be disabled
  652. in registered versions of ULP, making ULPTEST seamless to look like a part of
  653. PCBoard itself. A sample follows:
  654.  
  655.     Verifying FILENAME.ZIP...
  656.     ┌────────────────────────────────┐
  657.     │      UpLoadProcessor 1.00      │  Registered to: Bloom Beacon-Picayune
  658.     │ Copyright 1992-93  Stacy Smith │  Serial number: 1000
  659.     └────────────────────────────────┘
  660.        Identifying file archive format...ZIP
  661.        Screening archive for corruption...OK
  662.        Unpacking archive...OK
  663.        Testing files for viruses, etc...OK
  664.        Checking for duplicate files...OK
  665.        Checking age of files...OK
  666.        Archive passed.
  667.  
  668. ULPTEST will return a DOS errorlevel of 0 if the archive is OK, and an
  669. errorlevel of 1-13 if there was an error (depending on the error). This allows
  670. the PCBTEST.BAT batch file to branch based upon the results of the ULPTEST. The
  671. appendix to this document lists all of the DOS errorlevels set by various ULP
  672. programs.
  673.  
  674. ULPTEST also creates the requires PCBPASS.TXT and PCBFAIL.TXT for PCBoard to
  675. determine if the archive passed or not.
  676.  
  677.  
  678. ┌────────────────────┐
  679. │  9. Configuration  │
  680. └────────────────────┘
  681.  
  682. ULPSM makes the configuration process very easy for the ULP system. The sample
  683. configuration files provided in the distribution archive contain much of the
  684. information required, but needs to be customized to some degree to fit your
  685. application.
  686.  
  687. To begin ULPSM, you must include a configuration filename on the command-line,
  688. denoted by the -C switch. For example, to edit the default configuration file,
  689. ULP.CFG, type:
  690.  
  691.     ULPSM -CULP.CFG
  692.  
  693. and the main menu screen will appear:
  694.  
  695. ┌───────────────────────────────┐┌─────────────── Registered To ──────────────┐
  696. │   ULP System Manager 1.00     ││                UNREGISTERED                │
  697. │ Copyright 1992-93 Stacy Smith ││              SYSOP - S/N 0000              │
  698. └───────────────────────────────┘└────────────────────────────────────────────┘
  699. ░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░
  700. ░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░
  701. ░░░░░░░░░░░░░░░░░░░░░░░┌────────────────────────────────┐░░░░░░░░░░░░░░░░░░░░░░
  702. ░░░░░░░░░░░░░░░░░░░░░░░│  A - Registration information  │░░░░░░░░░░░░░░░░░░░░░░
  703. ░░░░░░░░░░░░░░░░░░░░░░░│  B - General options           │░░░░░░░░░░░░░░░░░░░░░░
  704. ░░░░░░░░░░░░░░░░░░░░░░░│  C - Upload directories        │░░░░░░░░░░░░░░░░░░░░░░
  705. ░░░░░░░░░░░░░░░░░░░░░░░│  D - Archiving options         │░░░░░░░░░░░░░░░░░░░░░░
  706. ░░░░░░░░░░░░░░░░░░░░░░░│  E - Archivers                 │░░░░░░░░░░░░░░░░░░░░░░
  707. ░░░░░░░░░░░░░░░░░░░░░░░│  F - Virus/file testers        │░░░░░░░░░░░░░░░░░░░░░░
  708. ░░░░░░░░░░░░░░░░░░░░░░░│  G - Duplicate checking        │░░░░░░░░░░░░░░░░░░░░░░
  709. ░░░░░░░░░░░░░░░░░░░░░░░│  H - Age checking              │░░░░░░░░░░░░░░░░░░░░░░
  710. ░░░░░░░░░░░░░░░░░░░░░░░│  I - BBS ad processing         │░░░░░░░░░░░░░░░░░░░░░░
  711. ░░░░░░░░░░░░░░░░░░░░░░░│  J - GIF file testing          │░░░░░░░░░░░░░░░░░░░░░░
  712. ░░░░░░░░░░░░░░░░░░░░░░░│  K - Description processing    │░░░░░░░░░░░░░░░░░░░░░░
  713. ░░░░░░░░░░░░░░░░░░░░░░░│  L - Online testing            │░░░░░░░░░░░░░░░░░░░░░░
  714. ░░░░░░░░░░░░░░░░░░░░░░░│  M - Special-case files        │░░░░░░░░░░░░░░░░░░░░░░
  715. ░░░░░░░░░░░░░░░░░░░░░░░│  N - Init process data file    │░░░░░░░░░░░░░░░░░░░░░░
  716. ░░░░░░░░░░░░░░░░░░░░░░░└────────────────────────────────┘░░░░░░░░░░░░░░░░░░░░░░
  717. ░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░
  718. ░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░
  719. ░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░
  720.  
  721. Using the up and down arrow keys, you can select any of the options. A shortcut
  722. is to type the letter preceding the option you wish to edit. If you press your
  723. escape key (ESC), the following pop-up question box will appear:
  724.  
  725.     ┌─────────────────────────────────────────────────────────────────┐
  726.     │  Do you wish to save the ULP configuration file (Y/N or Esc)?   │
  727.     └─────────────────────────────────────────────────────────────────┘
  728.  
  729. To save any edits you made to the data to the disk configuration file, type
  730. "Y", otherwise type "N" or press the ESC again. Note that, with the exception
  731. of the upload directory configuration information, no data is saved until you
  732. do so when exiting ULPSM.
  733.  
  734. A - REGISTRATION INFORMATION
  735. ────────────────────────────
  736. When selected, the following pop-up box will appear. By using the up and down
  737. arrow keys, you can move the cursor to the desired field to be edited.
  738.  
  739.     ┌───────────────────────────────────────────────────────────────┐
  740.     │  Sysop name         SYSOP                                     │
  741.     │  BBS name           UNREGISTERED                              │
  742.     │  Registration code  0000000000                                │
  743.     └───────────────────────────────────── [F10] Keep  [ESC] Abort ─┘
  744.  
  745. Sysop name - Enter EXACTLY as provided to you on your registration letter. If
  746.     this is an unregistered version, leave the default of SYSOP. Note that this
  747.     field is case-sensitive!
  748. BBS name - Enter EXACTLY as provided to you on your registration letter. If
  749.     this is an unregistered version, leave the default of "UNREGISTERED". This
  750.     field is also case-sensitive!
  751. Registration code - Enter EXACTLY as provided to you on your registration
  752.     letter. If this is an unregistered version, leave the default of
  753.     "0000000000". This is also case-sensitive...you get the picture by now...
  754.  
  755. After editing the fields, press F10 to keep the edits, or press ESC to abort
  756. the changes. In either instance, you will be returned to the main menu after
  757. the data has been automatically checked for errors. Any errors detected in the
  758. data will generate a pop-up error window that describes the error.
  759.  
  760. B - GENERAL OPTIONS
  761. ───────────────────
  762. When selected, the following pop-up box will appear. By using the up and down
  763. arrow keys, you can move the cursor to the desired field to be edited.
  764.  
  765.     ┌─────────────────────────────────────────────────────────┐
  766.     │  Error disposition  (Keep/Delete/Rename)  R             │
  767.     │  Virus disposition  (Keep/Delete/Rename)  R             │
  768.     │  Work subdirectory      D:\WORK\                        │
  769.     │  Disk log file          C:\ULP\ULP.LOG                  │
  770.     │  Disk logging mode  (Terse/Verbose)  V                  │
  771.     │  Disk read buffer size  (K)          4                  │
  772.     │  Swapping (None/Ems/Xms/Disk/Auto)   A                  │
  773.     │  Internal file deletion  (Yes/No)    Y                  │
  774.     │  Update DOWNLOAD.TXT file  (Yes/No)  Y                  │
  775.     │  DOWNLOAD.TXT file      C:\PCB\MAIN\DOWNLOAD.TXT        │
  776.     │  Privileged users list  C:\ULP\PRIVUSER.LST             │
  777.     │  File viewing utility   LIST @FILE@                     │
  778.     └─────────────────────────────── [F10] Keep  [ESC] Abort ─┘
  779.  
  780. Error Disposition - This defines how ULP dispositions archives found to have an
  781.     error other than a file check failure. These kind of errors take the form
  782.     of ZIP CRCs, duplication, age, etc., and are not potentially system-
  783.     damaging. Under some conditions, these archives can be restored. If you
  784.     want ULP to delete the failed archive and description, enter "D"; if you
  785.     want ULP to rename the archive to a error extension, enter "R". If, for
  786.     some reason, you wish to keep the files without renaming, enter "K".
  787. Virus Disposition - This defines how ULP dispositions archives that fail a file
  788.     check, such as a virus scan. These errors are potentially system-damaging.
  789.     If you want ULP to delete the failed archive and description, enter "D"; if
  790.     you want ULP to rename the archive to a .CHK extension, enter "R". If you
  791.     wish to keep the defective files without renaming, enter "K".
  792. Work subdirectory - If you want ULP, ULPTEST or ULPDB to use a specific
  793.     subdirectory for storage while processing, enter the full pathname
  794.     (including the trailing backslash; ULPSM will add it if necessary.). The
  795.     drive letter MUST be included. If this directory does not exist at runtime,
  796.     the ULP programs will attempt to create it. This can be set to a RAM disk
  797.     for greater speed. ULP will check the drive specified for at least 5 times
  798.     the archive size before attempting to decompress the archive. If you do not
  799.     desire to use a specific directory, leave it blank (the ULP programs will
  800.     extract on the drive from which it was executed). ULP will also accept an
  801.     environment variable defined using the '%VARIABLE%' convention. Note that
  802.     the environment variable must conform to the rules (trailing backslash,
  803.     path length, etc.).
  804. Disk log file - All of the ULP programs will write process and error
  805.     information to a log file, if desired. This is the path/filename of the log
  806.     file for ULP to record its activities. Leave it blank if you don't want any
  807.     disk logging.
  808. Disk logging mode - If you want ULP and ULPTEST to record statistics for each
  809.     archive processed to the log file (verbose mode), enter "V". If you only
  810.     want errors and disposition information (terse mode), logged to disk, enter
  811.     "T". Verbose mode will quickly produce a large log file, but gives much
  812.     more insight into what ULP is doing and why a particular upload failed.
  813. Disk read buffer size - The size of the disk I/O buffer you wish to allocate in
  814.     kilobytes (valid values are between 2K bytes and 16K bytes). Optimal
  815.     performance is obtained with a value that is a multiple of 2K bytes, since
  816.     this is the size of a typical hard disk cluster. 4K seems to be a good
  817.     number for me, although a larger size may improve performance a little. If
  818.     you find yourself running out of memory when executing archivers or file
  819.     checking programs, reduce this number to increase your available memory.
  820. Swapping - If you wish the ULP programs to swap themselves out of memory prior
  821.     to executing external programs, set this parameter to the type of swapping
  822.     desired (E for EMS, X for XMS, D for disk and A for automatic swap device
  823.     selection). If you do not want this feature, enter "N". This feature will
  824.     be of most benefit to users using ARJ to compress archives, networked
  825.     systems and small DESQview windows. Use this feature ONLY if you have a
  826.     memory crunch (refer to the file SWAPPING.DOC for more information).
  827. Internal file deletion - If the ULP programs are to delete the extracted files
  828.     themselves, versus using DOS, set this parameter to "Y". If not, enter "N".
  829.     In some cases, letting DOS do the work is faster, but foreign language
  830.     implementations of DOS may prevent this ability, since they do not all use
  831.     "Y" as the acceptance character.
  832. Update DOWNLOAD.TXT file - If ULP is to scan your DOWNLOAD.TXT file and update
  833.     the file extension of the upload to reflect the correct archiving method
  834.     used, enter "Y", otherwise enter "N". This feature will allow utilities
  835.     that scan DOWNLOAD.TXT for file information to reflect correct information.
  836.     If you are using a utility that creates an independent database from the
  837.     DOWNLOAD.TXT file, such as PCBFX version 2.x, be sure ULP.EXE is run in the
  838.     event BEFORE that utility so the independent database reflects the changes
  839.     that ULP makes to DOWNLOAD.TXT.
  840. DOWNLOAD.TXT file - The full path and filename for the DOWNLOAD.TXT file. This
  841.     field is necessary only if the "Update DOWNLOAD.TXT file" is set to "Y".
  842. Privileged user list - ULP can use an ASCII text file to disable duplication
  843.     and age failures if the user's name is listed in this file. If you wish to
  844.     use this function, enter the full path and filename for the list file,
  845.     otherwise, leave it blank. The format of the file is a single name
  846.     per line; case is not important.
  847. File viewing utility - The command line for an ASCII file viewing (or editing)
  848.     utility, such as Vernon Buerg's venerable LIST utility. This will be called
  849.     by ULPDB to facilitate viewing of an archive information file generated for
  850.     the purposes of archive review. Place the @FILE@ variable (all caps) where
  851.     the filename is to be entered on the utility's command line.
  852.  
  853. After editing the fields, press F10 to keep the edits, or press ESC to abort
  854. the changes. In either instance, you will be returned to the main menu after
  855. the data has been automatically checked for errors.
  856.  
  857. C - UPLOAD DIRECTORIES
  858. ──────────────────────
  859. When selected, the following pop-up box will appear. By using the up and down
  860. arrow keys, you can move the cursor to the desired field to be edited.
  861.  
  862.     ┌────────────────────────────────────────────────────────────────┐
  863.     │  Upload directory config file  C:\ULP\ULPDIR.CFG               │
  864.     │  Upload directory definitions page number  (1-8)  1            │
  865.     └───────────────────────────────────────────── [Enter] Continue ─┘
  866.  
  867. Upload directory config file - The filename of the upload directory
  868.     configuration file for ULP. This file is automatically created by ULPSM.EXE
  869.     from data entered in the following screen(s), and must be defined for ULP
  870.     to operate.
  871. Upload directory definitions page number - The editing of the upload
  872.     directories is broken into 8 pages, with 3 directories per screen. You can
  873.     configure a total of 24 directories to be processed by ULP (this was an
  874.     arbitrarily-chosen limit, and can be changed if desired). Enter the number
  875.     of the page you wish to edit.
  876.  
  877. After editing the fields, press ENTER to continue. The following pop-up box
  878. will appear, displaying the page requested:
  879.  
  880.     ┌─────────────────────────────────────────────────────────────────────────┐
  881.     │  Source directory path                  C:\PRIVATE1\                    │
  882.     │  Source directory list file             C:\PCB\GEN\PRIVDIR1             │
  883.     │  Number of header lines in source list  1                               │
  884.     │  Destination directory path             C:\PUBLIC1\                     │
  885.     │  Destination directory list file        C:\PCB\GEN\PUBLDIR1             │
  886.     │                                                                         │
  887.     │  Source directory path                  C:\PUBLIC2\                     │
  888.     │  Source directory list file             C:\PCB\GEN\PUBLDIR2             │
  889.     │  Number of header lines in source list  1                               │
  890.     │  Destination directory path                                             │
  891.     │  Destination directory list file                                        │
  892.     │                                                                         │
  893.     │  Source directory path                                                  │
  894.     │  Source directory list file                                             │
  895.     │  Number of header lines in source list  0                               │
  896.     │  Destination directory path                                             │
  897.     │  Destination directory list file                                        │
  898.     └─ Page 1 of 8 ───────────────────────────────── [F10] Save  [ESC] Abort ─┘
  899.  
  900. Source directory path - The directory where the uploads are placed by PCBoard.
  901.     This must include the trailing backslash, ULPSM will add it if necessary.
  902.     If you have "make all uploads private" in PCBSETUP set to "Y", this will be
  903.     your private upload subdirectory; if set to "N", this will be your public
  904.     upload subdirectory. This path must match EXACTLY the appropriate path in
  905.     PCBSETUP (e.g. don't have one named 'C:\DIR\' and the other just '\DIR\').
  906. Source directory list file - The upload directory list file that corresponds to
  907.     the subdirectory defined in "Source directory path" containing the archive
  908.     descriptions.
  909. Number of header lines in source list - The number of lines to ignore at the
  910.     beginning of the source directory list file (for headers, detachable header
  911.     filespecs, etc.)
  912. Destination directory path - The directory where the uploads are to be placed
  913.     by ULP after processing. This must include the trailing backslash, ULPSM
  914.     will add it if necessary. If you have "make all uploads private" in
  915.     PCBSETUP set to "Y", this will be your public upload subdirectory. If you
  916.     have "make all uploads private" set to "N", leave this field blank.
  917. Destination directory list file - The upload directory list file that
  918.     corresponds to the subdirectory defined in "Destination directory path"
  919.     containing the archive descriptions, or blank if "Destination directory
  920.     path" was left blank.
  921.  
  922. After editing the fields on this page, press F10 to save the edits to the
  923. upload directory configuration file on disk, or press ESC to abort the changes.
  924.  
  925. D - ARCHIVING OPTIONS
  926. ─────────────────────
  927. When selected, the following pop-up box will appear. By using the up and down
  928. arrow keys, you can move the cursor to the desired field to be edited.
  929.  
  930.     ┌─────────────────────────────────────────────────┐
  931.     │  Convert archives  (Yes/No)                  Y  │
  932.     │  Convert nested archives  (Yes/No)           N  │
  933.     │  Convert self-extracting archives  (Yes/No)  N  │
  934.     │  Convert -AV stamped ZIP archives  (Yes/No)  N  │
  935.     │  Convert secured ARJ archives  (Yes/No)      N  │
  936.     └─────────────────────── [F10] Keep  [ESC] Abort ─┘
  937.  
  938. Convert archives - If you want ULP to convert the archive to a default
  939.     archiving format of your choice, enter "Y"; if not, enter "N". This only
  940.     affects the 'root' level of the archive. This flag has no affect on the
  941.     conversion of internal, nested archives.
  942. Convert nested archives - If you want ULP to convert any internal archives
  943.     found inside the archive to your default archiving format, type "Y";
  944.     otherwise, type "N", and they will be rearchived using the original
  945.     archiving method (using the original extension, even if it isn't that
  946.     archiver's default extension). The benefit of converting nested archives is
  947.     that it may save some disk space; on the down side, it will potentially
  948.     break automatic installation programs/batch files that may be contained
  949.     within the archive that expect a certain format nested file.
  950. Convert self-extracting archives - If you want ULP to convert a self-extracting
  951.     (SFX) archive to your default archiving format, type "Y"; if not, type "N".
  952.     If NO is selected, the SFX archive will be processed, and then left alone
  953.     if it passes (NOT re-archived!). The reasoning for this is the LHA
  954.     autostart batch files and other similar features; they are usually used for
  955.     novice users and for automatic installation. By converting SFX archives,
  956.     this may save some disk space, but can cause inconveniences. For example,
  957.     if you don't have PKZnnn.EXE on your BBS, a novice user has no way of
  958.     obtaining the PKZIP utilities from your BBS. If there is a BBS ad in a SFX
  959.     archive, and this flag is set to "N", the ad will remain in the archive.
  960.     Can't be helped at the moment...
  961. Convert -AV stamped ZIP archives - If you want ULP to convert ZIP archives with
  962.     authenticity verification stamps (-AV), enter "N". If you set this flag to
  963.     "Y", then the original archive will be retained after processing. If there
  964.     is a BBS ad in a -AV stamped archive, and this flag is set to "N", the ad
  965.     will remain in the archive.
  966. Convert secured ARJ archives - If you want ULP to convert ARJ archives with
  967.     security envelopes (similar to a ZIP -AV), then set this to "Y". If you set
  968.     this flag to "N", then the original archive will be retained. If there is a
  969.     BBS ad in a secured archive, and this flag is set to "N", the ad will
  970.     remain in the archive.
  971.  
  972. After editing the fields, press F10 to keep the edits, or press ESC to abort
  973. the changes.
  974.  
  975. E - ARCHIVERS
  976. ─────────────
  977. When selected, the following pop-up box will appear:
  978.  
  979.     ┌──────────────────────────────────────────────┐
  980.     │  Archiver definitions page number  (1-3)  1  │
  981.     └─────────────────────────── [Enter] Continue ─┘
  982.  
  983. Archiver definitions page number - The editing of the archiver information is
  984.     broken into 3 pages, with 3 archivers per screen. You can configure a total
  985.     of 9 archivers to be utilized by ULP (this was an arbitrarily-chosen limit,
  986.     and can be changed if desired). Enter the number of the page you wish to
  987.     edit.
  988.  
  989. After editing the field, press ENTER to continue. The following pop-up box will
  990. appear, displaying the page requested:
  991.  
  992.     ┌─────────────────────────────────────────────────────────────────────────┐
  993.     │ Extension  ARC    Primary format (Yes/No)  N   Successful errorlevel  0 │
  994.     │ Pack     c:\util\pkpak -a @ARC@ @FILE@                                  │
  995.     │ Unpack   c:\util\pkunpak -r @ARC@                                       │
  996.     │ Test     c:\util\pkunpak -t @ARC@                                       │
  997.     │ Comment                                                                 │
  998.     │                                                                         │
  999.     │ Extension  ARJ    Primary format (Yes/No)  N   Successful errorlevel  0 │
  1000.     │ Pack     c:\util\arj a -e -jm -m1 @ARC@ @FILE@                          │
  1001.     │ Unpack   c:\util\arj e -y @ARC@                                         │
  1002.     │ Test     c:\util\arj t @ARC@                                            │
  1003.     │ Comment  c:\util\arj c -zc:\ulp\comment.txt @ARC@                       │
  1004.     │                                                                         │
  1005.     │ Extension  HYP    Primary format (Yes/No)  N   Successful errorlevel  0 │
  1006.     │ Pack     c:\util\hyper -a @ARC@ @FILE@                                  │
  1007.     │ Unpack   c:\util\hyper -x @ARC@                                         │
  1008.     │ Test     c:\util\hyper -v @ARC@                                         │
  1009.     │ Comment                                                                 │
  1010.     └─ Page 1 of 3 ───────────────────────────────── [F10] Keep  [ESC] Abort ─┘
  1011.  
  1012. Extension - The default extension for this particular archiving format. ULP is
  1013.     capable of automatically detecting ARC, ARJ, HYP, LZH, PAK, SQZ, ZIP and
  1014.     ZOO archives, and will process them regardless of extension. If you add
  1015.     another archiver that is not automatically detected by ULP, it will be
  1016.     detected by the configured extension only.
  1017. Primary format - If this is the default archiving format you use on your BBS,
  1018.     type "Y"; if not, type "N". There can be only one default archiver, and
  1019.     in the event more than one flag is set, ULPSM will take the first one in
  1020.     the list with the flag set as the default.
  1021. Successful errorlevel - The errorlevel that the archiver returns upon a
  1022.     successful execution. This information should be available in the program's
  1023.     documentation. This is how ULP determines if an archiver is functioning
  1024.     properly, so any archiver configured must return errorlevels that are
  1025.     different for success than errors.
  1026. Pack - The command line to pack archives, including all command-line switches
  1027.     desired. Place the variable @ARC@ (all caps) where the filename is to be
  1028.     inserted in the command line and @FILE@ (also all caps) where the filespec
  1029.     is to be inserted. This cannot be a batch file, nor is DOS re-direction
  1030.     allowed. If you do not explicitly define the path to your archiver(s), it
  1031.     must in a directory included in the DOS 'PATH' environment variable.
  1032. Unpack - The command line to unpack archives, including all command-line
  1033.     switches desired. Place the variable @ARC@ where the filename is to be
  1034.     inserted in the command line. This cannot be a batch file, nor is DOS
  1035.     re-direction allowed.
  1036. Test - The command line for the archiver to test archive integrity, including
  1037.     all command-line switches desired. Place the variable @ARC@ where the
  1038.     filename is to be inserted in the command line. This cannot be a batch
  1039.     file, nor is DOS re-direction allowed.
  1040. Comment - The command line to comment archives. Place the variable @ARC@ where
  1041.     the filename is to be inserted in the command line. If the archiver does
  1042.     not support comments, or if you do not wish to add comments, leave the
  1043.     field blank. This cannot be a batch file, but DOS redirection is permitted
  1044.     to pipe a file into the archiver (PKZIP, for example).
  1045.  
  1046. After editing the fields, press F10 to keep the edits, or press ESC to abort
  1047. the changes.
  1048.  
  1049. F - VIRUS/FILE TESTERS
  1050. ──────────────────────
  1051. When selected, the following pop-up box will appear. By using the up and down
  1052. arrow keys, you can move the cursor to the desired field to be edited.
  1053.  
  1054.     ┌─────────────────────────────────────────────────────────────────────────┐
  1055.     │  Command 1  h:\util\scan /a /nomem /nopause @FILE@                      │
  1056.     │  Successful errorlevel  0                                               │
  1057.     │                                                                         │
  1058.     │  Command 2                                                              │
  1059.     │  Successful errorlevel  0                                               │
  1060.     │                                                                         │
  1061.     │  Command 3                                                              │
  1062.     │  Successful errorlevel  0                                               │
  1063.     └─────────────────────────────────────────────── [F10] Keep  [ESC] Abort ─┘
  1064.  
  1065. Command n - The command line to execute for the file checker, including all
  1066.     command-line switches. Place the variable @FILE@ where the filespec is to
  1067.     be placed on the command line. This cannot be a batch file, nor is DOS
  1068.     re-direction allowed. Any kind of file checker may be used, such as a virus
  1069.     checker or a BBS ads checker, if desired; they will be executed in the
  1070.     order defined in this screen. If you do not explicitly define the path to
  1071.     your file checking program(s), it must in a directory included in the DOS
  1072.     PATH environment variable. Note that if you are running a network, the use
  1073.     of network-specific scanners may be necessary (e.g. McAfee's SCAN and
  1074.     NETSCAN).
  1075. Successful errorlevel - The errorlevel that the file checker returns upon a
  1076.     successful execution. This information should be available in the program's
  1077.     documentation. This is how ULP determines if the file checker detected a
  1078.     defect, so any file checker configured must return errorlevels that are
  1079.     different for success than errors.
  1080.  
  1081. After editing the fields, press F10 to keep the edits, or press ESC to abort
  1082. the changes.
  1083.  
  1084. G - DUPLICATE CHECKING
  1085. ──────────────────────
  1086. When selected, the following pop-up box will appear. By using the up and down
  1087. arrow keys, you can move the cursor to the desired field to be edited.
  1088.  
  1089.     ┌────────────────────────────────────────────────────────────────────────┐
  1090.     │  Duplication checking  (None/Internal/Zdcs)  I                         │
  1091.     │  Total duplication limit  (%)                55                        │
  1092.     │  Executable dupe limit  (%)                  80                        │
  1093.     │  Database buffer size  (Small/Medium/Large)  80                        │
  1094.     │  Duplication database        C:\ULP\DATABASE.DB                        │
  1095.     │  Duplication database index  C:\ULP\DATABASE.IDX                       │
  1096.     │  ZDCS subdirectory                                                     │
  1097.     └────────────────────────────────────────────── [F10] Keep  [ESC] Abort ─┘
  1098.  
  1099. Duplication checking - If you want ULP to use its internal duplication system
  1100.     checking, type "I". If you want to use the ZDCS external duplication system
  1101.     by Mike Cocke (with the required ZCDSULP interface program), enter "Z". If
  1102.     you desire no duplication checking at all, type "N".
  1103. Total duplication limit - The minimum percentage of duplication allowed for a
  1104.     file to pass. Anything SMALLER will pass regardless of the executable
  1105.     duplication limit. I would suggest this number be set to around 55, as some
  1106.     program authors don't modify every file, especially with maintenance
  1107.     releases. This limit is implemented for both ULP's internal and ZDCS
  1108.     duplication systems.
  1109. Executable dupe limit - The maximum percentage of duplication allowed for
  1110.     executable files and overlays to pass. This number should be higher than
  1111.     the total duplication limit; I would recommend about 80. This will catch
  1112.     archives that are duplicates, but someone has changed enough files to
  1113.     normally pass it when uploaded (such as configs, high score files, etc.).
  1114.     This will also pass files where the author has changed nothing but the
  1115.     executables; they would have failed before. Executables are determined
  1116.     solely by extension; any file with one of the following extensions will be
  1117.     counted as an executable: EXE, COM, SYS, OVL, OVR, DLL. This limit is also
  1118.     implemented for both ULP's internal and ZDCS duplication systems.
  1119. Database Buffer Size - Three buffer sizes are available for optimum database
  1120.     speed and memory usage. The sizes are 2.5K, 5K and 10K for the small,
  1121.     medium and large buffers, respectively. Enter "S" for a small, "M" for a
  1122.     medium or "L" for a large database buffer. For small databases (less than
  1123.     1 meg in size) or severe memory conditions, select the small buffer. For
  1124.     databases over 3 megs, the large buffer should prove slightly faster than
  1125.     the medium size, although the difference won't be as noticeable. This
  1126.     buffer is used for ULP's internal duplication system only; no buffer is
  1127.     allocated for ZDCS usage.
  1128. Duplication database - The path and name for the duplication database file.
  1129.     It's a good idea to keep the database and index file together, just to make
  1130.     things easier. This file is used for ULP's internal duplication system
  1131.     only.
  1132. Duplication database index - The path and name for the duplication database
  1133.     file index. This file is also used for ULP's internal duplication system
  1134.     only.
  1135. ZDCS subdirectory - The complete path for your ZDCS files (used only for the
  1136.     ZDCS duplication system). You must include the trailing backslash and drive
  1137.     letter; ULPSM will add it if necessary.
  1138.  
  1139. After editing the fields, press F10 to keep the edits, or press ESC to abort
  1140. the changes.
  1141.  
  1142. H - AGE CHECKING
  1143. ────────────────
  1144. When selected, the following pop-up box will appear. By using the up and down
  1145. arrow keys, you can move the cursor to the desired field to be edited.
  1146.  
  1147.     ┌──────────────────────────────────────────┐
  1148.     │  Age checking  (None/Average/neWest)  A  │
  1149.     │  Minimum age  (months)  48               │
  1150.     └──────────────── [F10] Keep  [ESC] Abort ─┘
  1151.  
  1152. Age checking - If you want ULP to fail an archive based on the average age of
  1153.     the files contained within, enter "A". If you want rejection based upon the
  1154.     age of the newest file, enter "W". Otherwise, if you don't want age
  1155.     checking, enter "N".
  1156. Minimum average age - The maximum average age in months, that you will accept
  1157.     for an upload.
  1158.  
  1159. After editing the fields, press F10 to keep the edits, or press ESC to abort
  1160. the changes.
  1161.  
  1162. I - BBS AD PROCESSING
  1163. ─────────────────────
  1164. When selected, the following pop-up box will appear. By using the up and down
  1165. arrow keys, you can move the cursor to the desired field to be edited.
  1166.  
  1167.     ┌─────────────────────────────────────────────────────────────┐
  1168.     │  Remove BBS ads  (Yes/No)   Y                               │
  1169.     │  BBS ad detection database  C:\ULP\ULPADS.DB                │
  1170.     │  BBS ad file to insert                                      │
  1171.     └─────────────────────────────────── [F10] Keep  [ESC] Abort ─┘
  1172.  
  1173. Remove BBS ads - If you want ULP to remove known BBS ads from new uploads
  1174.     during processing, type "Y"; if not, type "N". Only ULP.EXE and ULPTEST
  1175.     SLOW mode removes BBS ads; ULPTEST FAST and NORMAL modes do not, but the
  1176.     upload will have any BBS ads removed later in the event.
  1177. BBS ad detection database - The path and name for the BBS ads database. This
  1178.     database can be updated by the sysop by using the ULPADS utility (see
  1179.     section 11 of this document), freeing the sysop from being reliant on me to
  1180.     maintain the ads database. If you find a large number of new BBS ad files,
  1181.     please upload them to my board for inclusion into my master ads database.
  1182. BBS ad file to insert - The path and filename for your BBS ad to be added to
  1183.     each and every archive processed by ULP. If you do not wish to insert a BBS
  1184.     ad, leave the field blank. Note that you must provide a drive and path, or
  1185.     it will not be copied. I STRONGLY recommend against them; BBS ads are
  1186.     aggravating to other sysops, so please be considerate and use the ARJ or
  1187.     ZIP comment instead. BBS ad files are the scourge of the BBS world.
  1188.  
  1189. After editing the fields, press F10 to keep the edits, or press ESC to abort
  1190. the changes.
  1191.  
  1192. J - GIF FILE CHECKING
  1193. ─────────────────────
  1194. When selected, the following pop-up box will appear. By using the up and down
  1195. arrow keys, you can move the cursor to the desired field to be edited.
  1196.  
  1197. * NOTE: If you desire no GIF file testing by ULP, set all minimum image
  1198.         parameters (width, height and colors) to 0 and blank out the GIF file
  1199.         tester command line.
  1200.  
  1201.     ┌─────────────────────────────────────────────────────────────────────────┐
  1202.     │  Minimum image width  (columns)  320                                    │
  1203.     │  Minimum image height  (rows)    200                                    │
  1204.     │  Minimum number of colors        16                                     │
  1205.     │  Keep GIFLITE'd files  (Yes/No)  N                                      │
  1206.     │  Command  giftest /b:0 /l:c:\ulp\giftest.log @FILE@                     │
  1207.     │  Successful errorlevel  0                                               │
  1208.     └─────────────────────────────────────────────── [F10] Keep  [ESC] Abort ─┘
  1209.  
  1210. Minimum image width - If ULP is to reject GIF files based upon image width,
  1211.     enter the minimum acceptable width in pixels. If no width limit is desired,
  1212.     set it to zero.
  1213. Minimum image height - If ULP is to reject GIF files based upon image height,
  1214.     enter the minimum acceptable height in pixels. If no height limit is
  1215.     desired, set it to zero.
  1216. Minimum number of colors - If ULP is to reject GIF files based upon the number
  1217.     of colors in the image, enter the minimum acceptable number of colors. If
  1218.     no color limit is desired, set it to zero.
  1219. Keep GIFLITE'd files - If ULP is to keep uploaded GIF files if they have been
  1220.     compressed with GIFLITE, set this to "Y". If not, set it to "N". At this
  1221.     time, if you use GIFTEST, this parameter will have no effect; GIFLITE'd
  1222.     files will always be rejected. Accepting GIFLITE'd GIF files can compromise
  1223.     the duplication system due to its variable compression ratio! I strongly
  1224.     suggest you do not accept GIFLITE'd GIF files!
  1225. Command - The command line to execute for the GIF file checker, including all
  1226.     command-line switches. Place the variable @FILE@ where the filespec is to
  1227.     be placed on the command line. This cannot be a batch file, nor is DOS
  1228.     re-direction allowed.
  1229. Successful errorlevel - The errorlevel that the GIF file checker returns upon a
  1230.     successful execution. This information should be available in the program's
  1231.     documentation. This is how ULP determines if the GIF file checker detected
  1232.     a defect in the GIF file, so the GIF file checker configured must return
  1233.     errorlevels that are different for success than errors.
  1234.  
  1235. After editing the fields, press F10 to keep the edits, or press ESC to abort
  1236. the changes.
  1237.  
  1238. K - DESCRIPTION PROCESSING
  1239. ──────────────────────────
  1240. When selected, the following pop-up box will appear. By using the up and down
  1241. arrow keys, you can move the cursor to the desired field to be edited.
  1242.  
  1243.     ┌─────────────────────────────────────────────────────────────────────────┐
  1244.     │  Strip lost descriptions  (Yes/No)             N                        │
  1245.     │  Smart word wrap descriptions  (Yes/No)        Y                        │
  1246.     │  Strip high ASCII from descriptions  (Yes/No)  N                        │
  1247.     │  Insert internal description files  (Yes/No)   Y                        │
  1248.     │  Maximum number of description lines           10                       │
  1249.     │  Number of columns to indent secondary lines   32                       │
  1250.     │  Insert error description line  (Yes/No)       Y                        │
  1251.     │  Insert lack of description line  (Yes/No)     Y                        │
  1252.     │  Archive information line format                                        │
  1253.     │  (Files: @#@ Newest: @NEW@ Oldest: @OLD@)                               │
  1254.     │  GIF information line format                                            │
  1255.     │  (Resolution: @WID@x@HGT@x@COLOR@  Comp: @COMP@)                        │
  1256.     └─────────────────────────────────────────────── [F10] Keep  [ESC] Abort ─┘
  1257.  
  1258. Strip lost descriptions - If you want ULP to remove "lost" descriptions from
  1259.     the source listing that do not have a corresponding file in the source
  1260.     subdirectory, enter "Y", otherwise, type "N". This is an excellent tool for
  1261.     cleaning up stray descriptions after files have been deleted for some
  1262.     reason.
  1263. Smart word wrap descriptions - If you want ULP to word-wrap descriptions, enter
  1264.     "Y", otherwise, type "N". Due to it's smart word-wrapping, ULP checks for
  1265.     box-draw characters before word-wrapping.
  1266. Strip high ASCII from descriptions - If you want ULP to strip high ASCII and
  1267.     control characters from archive descriptions prior to insertion, enter "Y",
  1268.     otherwise, enter "N". When turned on, ULP will strip all illegal characters
  1269.     (per the FILE_ID.DIZ specification) from descriptions prior to insertion,
  1270.     leaving the text description intact.
  1271. Insert internal description files - ULP can extract and insert FILE_ID.DIZ and
  1272.     DESC.SDI internal description files into the directory list files. If you
  1273.     want ULP to insert internal description files, type "Y"; if not, type "N".
  1274.     Note that ULP gives priority to FILE_ID.DIZ in the event the same archive
  1275.     contains both a FILE_ID.DIZ and a DESC.SDI file.
  1276. Maximum number of description lines - When ULP is to insert internal
  1277.     description files, this is the maximum number of lines that ULP will insert
  1278.     from the description file. Although up to 60 lines can be inserted, Clark
  1279.     Development Company (the developer of PCBoard and FILE_ID.DIZ) has defined
  1280.     that a FILE_ID.DIZ file should have no more than 10 lines.
  1281. Number of columns to indent secondary lines - The column where the '|' marker
  1282.     goes in your directory listing setup for secondary description lines and
  1283.     information lines added by ULP. The standard PCBoard setup indents to
  1284.     column 32.
  1285. Insert error description line - If you want ULPTEST to add a canned line to the
  1286.     description of failed archives describing the failure, enter "Y",
  1287.     otherwise, type "N". Note that ULP.EXE will not add this line, nor will it
  1288.     strip this error line if the file is processed in override mode.
  1289. Insert lack of description line - If you want ULP.EXE to insert a canned "No
  1290.     description available" line for the description of any file that does not
  1291.     have any description associated with it, set this to "Y". If you wish for
  1292.     the file to remain in the source area without a description of any kind,
  1293.     set to "N".
  1294. Archive information line format - The format that you would like for the
  1295.     archive information line (do not include the '|' character or the following
  1296.     space; ULP will add those). If you do not wish to include an archive
  1297.     information line, blank this field out. This format is completely
  1298.     configurable by the user; any ASCII character can be used. To include
  1299.     specific information compiled by ULP, just add the variables. The legal
  1300.     variables must be in all caps, and are as follows:
  1301.         @#@     Number of files in the archive (and nested archives)
  1302.         @NEW@   Date of the newest file in the archive
  1303.         @OLD@   Date of the oldest file in the archive
  1304.         @BYTE@  The total number of bytes (uncompressed) in the archive
  1305.         @DATE@  Today's date
  1306.         @CR@    Inserts a line break for multiline capability
  1307. GIF information line format - The format that you would like for the GIF
  1308.     information line (again, do not include the '|' character or the space). If
  1309.     you do not wish to include a GIF information line, blank this field out.
  1310.     The legal variables are:
  1311.         @WID@    Horizontal resolution (number of columns)
  1312.         @HGT@    Vertical resolution (number of rows)
  1313.         @COLOR@  Number of colors in GIF
  1314.         @COMP@   Inserts "GIFLITE" or "None", depending upon compression
  1315.         @DATE@   Today's date
  1316.         @CR@     Inserts a line break for multiline capability
  1317.  
  1318. After editing the fields, press F10 to keep the edits, or press ESC to abort
  1319. the changes.
  1320.  
  1321. L - ONLINE TESTING
  1322. ──────────────────
  1323. When selected, the following pop-up box will appear. By using the up and down
  1324. arrow keys, you can move the cursor to the desired field to be edited.
  1325.  
  1326.     ┌──────────────────────────────────────────────────────┐
  1327.     │  Default online test mode  (Fast/Normal/Slow)  S     │
  1328.     │  Maximum file size for slow mode  (K)          250   │
  1329.     │  Maximum file size for normal mode  (K)        500   │
  1330.     │  Generate remote user status screen  (Yes/No)  N     │
  1331.     │  Suppress ULP header in serial I/O  (Yes/No)   N     │
  1332.     └──────────────────────────── [F10] Keep  [ESC] Abort ─┘
  1333.  
  1334. Default online test mode - This defines the default mode that ULPTEST processes
  1335.     an archive. The default mode is the mode that ULPTEST *starts* in, and then
  1336.     is forced into the faster mode(s) by the limits defined.
  1337.     SLOW mode fully processes the archive, identical to the ULP event
  1338.         processing except that the archive formats are not converted. Note that
  1339.         archive conversion is not possible in SLOW mode due to limitations of
  1340.         PCBoard and the file will not be reprocessed by ULP.EXE in the event.
  1341.         Also note that you MUST make all uploads public for SLOW mode to work
  1342.         properly. This mode is intended to emulate the operation of other
  1343.         testers like EXZTest and Ziplab. Enter "S" to use this mode.
  1344.     NORMAL mode is a full *test*, except the archive is not repacked, saving a
  1345.         significant amount of the testing time for the online user. Enter "N"
  1346.         to use this mode of operation.
  1347.     FAST indicates a fast test in which the archive is scanned for archive
  1348.         integrity, duplicates, and age without unpacking the archive (ARJ and
  1349.         ZIP files only). If this mode is used, it should be held for later
  1350.         reprocessing by ULP.EXE so that it can be file-checked. Note that FAST
  1351.         mode can only 'see' one level deep in the archive. If you have a slow
  1352.         computer and/or hard disk, FAST mode would be preferable for your users
  1353.         when large archives are uploaded. Enter "F" to utilize this mode.
  1354. Maximum file size for slow mode - If SLOW mode is used, the archive's file size
  1355.     will first be compared against this limit (in kilobytes). If it is larger
  1356.     than this number of bytes (in kilobytes), it will be forced into NORMAL
  1357.     mode to speed the process and prevent wasting the user's online time.
  1358.     Entering 0 will disable this feature, resulting in SLOW mode being used at
  1359.     all times. If the default online test mode is set to NORMAL or FAST, this
  1360.     parameter has no effect.
  1361. Maximum file size for normal mode - If NORMAL mode is used (or has been forced
  1362.     due to an upload exceeding the slow mode size limit), the archive's file
  1363.     size will be compared against this limit (in kilobytes). If it is larger
  1364.     than this number of kilobytes, it will be forced into FAST mode to speed
  1365.     the process and prevent wasting the user's online time. Entering 0 will
  1366.     disable this feature, resulting in NORMAL mode being used at all times. If
  1367.     the default test mode is set to FAST, this parameter has no effect.
  1368. Generate online user status - If you want ULPTEST to output status information
  1369.     to the user on-line, set this flag to "Y"; if you do not want ULPTEST to
  1370.     output status information, enter "N". ULPTEST supports both direct
  1371.     interrupt-driven I/O (IRQs 2-7) and FOSSIL driver I/O.
  1372. Suppress ULP header in serial I/O - If you want ULPTEST to suppress the program
  1373.     header output to the user via the COM port (the program name, copyright
  1374.     notice, and registration information). This gives a seamless look for ULP
  1375.     into PCBoard. If this is desired, set this flag to "Y"; otherwise, set it
  1376.     to "N". This feature will work for registered users only!
  1377.  
  1378. After editing the fields, press F10 to keep the edits, or press ESC to abort
  1379. the changes.
  1380.  
  1381. M - SPECIAL-CASE FILES
  1382. ──────────────────────
  1383. When selected, the following pop-up box will appear. By using the up and down
  1384. arrow keys, you can move the cursor to the desired field to be edited.
  1385.  
  1386.     ┌────────────────────────────────────────────────────┐
  1387.     │  Uncompressed extensions to process and compress   │
  1388.     │  DOC  TXT  COM                                     │
  1389.     │                                                    │
  1390.     │                                                    │
  1391.     │  Extensions to pass without processing             │
  1392.     │  CPT  SIT                                          │
  1393.     │                                                    │
  1394.     └────────────────────────── [F10] Keep  [ESC] Abort ─┘
  1395.  
  1396. Uncompressed extensions to process and compress - ULP can process selected
  1397.     uncompressed uploads, using this option. Up to 24 uncompressed file types
  1398.     can be specified by extension. Do not use any compression format extensions
  1399.     (ARJ, ZIP, etc.)! Any files that are uploaded with one of these extensions
  1400.     and could not be identified by signature will be file-checked,
  1401.     duplicate-checked, and compressed using your default archiving method (in
  1402.     the event). If you do not want to use this feature, simply blank all of the
  1403.     fields. It probably is not a good idea to have EXE as an extension to
  1404.     compress, since ULP is not able to detect ARC, HYP or ZOO self-extractors,
  1405.     and they would be packed again as an uncompressed archive.
  1406. Extensions to pass without processing - ULP can be forced to NOT process
  1407.     selected uploads, using this option. Up to 24 file types can be specified
  1408.     by extension. THESE FILES WILL BE AUTOMATICALLY PASSED WITHOUT ANY TESTING;
  1409.     be sure this is desired. This is intended for use with non-DOS uploads,
  1410.     such as the Unix Tar Z format, or Macintosh files. Since these files will
  1411.     NOT be tested for viruses, etc., note this fact to your users.
  1412.  
  1413. After editing the fields, press F10 to keep the edits, or press ESC to abort
  1414. the changes.
  1415.  
  1416. N - INIT PROCESS DATA FILE
  1417. ──────────────────────────
  1418. When selected, the following pop-up box will appear. By using the up and down
  1419. arrow keys, you can move the cursor to the desired field to be edited.
  1420.  
  1421.     ┌─────────────────────────────────────────────────────┐
  1422.     │  Process data file  C:\ULP\PROCESS.DAT              │
  1423.     │  Initialize process data file  N                    │
  1424.     └───────────────────────────── [F10] Go  [ESC] Abort ─┘
  1425.  
  1426. Process data file - The path and filename of the ULP process data file. This
  1427.     file contains information on previous ULP archive processing and is
  1428.     maintained automatically by ULP. This file must exist, or ULP will not
  1429.     operate.
  1430. Initialize process data file - If you want ULPSM to initialize the process data
  1431.     file when the F10 key (Go) is pressed, enter "Y", otherwise leave it as
  1432.     "N". Note that the process data file can also be initialized using ULP.EXE
  1433.     with the -I command line switch.
  1434.  
  1435. After editing the fields, press F10 to initialize the process data file and
  1436. keep the edits, or press ESC to abort the changes.
  1437.  
  1438.  
  1439. ┌────────────────────────┐
  1440. │  10. Manual Operation  │
  1441. └────────────────────────┘
  1442.  
  1443. While the ULP system is mostly automatic, there are occasions where some
  1444. operations may have to be done manually:
  1445.  
  1446. ULP:
  1447. ────
  1448. During the course of operation, ULP will rename archives that have been found
  1449. to be defective in some manner according to the following convention:
  1450.  
  1451.     .UNK    Unknown archive format
  1452.     .DOS    DOS reserved keyword found in archive
  1453.     .ERR    Error occurred while unpacking archive (archive integrity failure)
  1454.     .CHK    Error found while file checking archive file (virus, etc.)
  1455.     .DUP    Excessive duplicate files contained in archive
  1456.     .PCK    Error occurred while repacking archive file
  1457.     .AGE    Age limit exceeded by archive file
  1458.     .ENC    Encrypted file found in archive
  1459.     .BAD    Error found while testing GIF file
  1460.     .RES    Unacceptable GIF resolution
  1461.     .GLT    GIF compressed with GIFLITE
  1462.     .WRK    Unable to create work space for processing file
  1463.  
  1464. I would enter these extensions in your UPSEC file, as ULP will automatically
  1465. pass over any file with these extensions, presuming that they are defective
  1466. archives. Doing so will prevent a user from uploading a file with one of these
  1467. "reserved" extensions.
  1468.  
  1469. If you feel that these files are acceptable after reviewing them, you can force
  1470. them to be accepted by adding the command-line switch -O (for override) to the
  1471. ULP command line, e.g.:
  1472.  
  1473.     ULP -CULP.CFG -O
  1474.  
  1475. This will accept the archives regardless of duplication or age limits. It will
  1476. not override unpacking, packing, integrity and virus errors, however, for the
  1477. safety of your board and your users.
  1478.  
  1479. To initialize the ULP process database without using ULPSM, use the -I command
  1480. line switch:
  1481.  
  1482.     ULP -CULP.CFG -I
  1483.  
  1484. ULP will scan your source upload directories as configured and generate a
  1485. process data file. From then on, ULP will maintain this data file
  1486. automatically.
  1487.  
  1488. Three other command-line parameters are available in ULP. '-R' will retest all
  1489. archives found in the subdirectory passed to it. It will not use duplication
  1490. checking or age checking, nor will it repack the archive; it was installed to
  1491. allow the periodic retesting of archives for viruses, etc.:
  1492.  
  1493.     ULP -CULP.CFG -Rc:\temp\
  1494.  
  1495. Another, '-M' will retest and convert all archives found in the subdirectory
  1496. indicated; this can be used for mass archive conversion:
  1497.  
  1498.     ULP -CULP.CFG -Mc:\temp\
  1499.  
  1500. Note that the '-R' and '-M' switches cannot be used on a CD-ROM or other
  1501. write-protected media at this time.
  1502.  
  1503. ULPTEST:
  1504. ────────
  1505. If you wish to run ULPTEST without any drop files for comm port configuration
  1506. (e.g. PCBOARD.DAT, PCBOARD.SYS, etc.), add the '-L' command-line switch to
  1507. force comm I/O off and prevent the search for drop files. For example:
  1508.  
  1509.     ULPTEST -CULP.CFG -F%1 -M%2 -D%3 -N%PCBNODE% -L
  1510.  
  1511. * NOTE:  When ULPTEST is run in local mode, it is not possible to support
  1512.     privileged users, since the user's name can only be extracted from
  1513.     PCBOARD.SYS.
  1514.  
  1515. You should also pass the node number with the -N parameter, as ULPTEST does not
  1516. have access to the drop files where this information is available. Otherwise,
  1517. it will default to a node number of 9999.
  1518.  
  1519. ULPDB:
  1520. ──────
  1521. If a file has been failed for some reason, you can view the contents of the
  1522. archive using the -V command switch with ULPDB. This will scan the archive, and
  1523. generate a report of the results, which are indicative of why it failed. For
  1524. example:
  1525.  
  1526.     ULPDB -CULP.CFG -Vc:\privul\archive.dup
  1527.  
  1528. This will produce a report of the archive ARCHIVE.DUP located in the specified
  1529. path. This can be useful in determining if an archive that failed duplication
  1530. should be removed or should be accepted anyway, and similar reasons.
  1531.  
  1532. In addition, duplication databases can be merged using the -M command-line
  1533. option. In order to merge a second database into your main database:
  1534.  
  1535.     ULPDB -CULP.CFG -Msecond.db
  1536.  
  1537. where 'second.db' is the full path and filename for the second duplication
  1538. database to be merged with the main duplication database.  This will allow
  1539. pre-built databases to be constructed for CD-ROM disks for easy implementation.
  1540.  
  1541. Finally, database entries can be purged from the database using the file date
  1542. contained in the database record using the -P command switch:
  1543.  
  1544.     ULPDB -CULP.CFG -P60
  1545.  
  1546. where '60' is the maximum age (in months) for a file to remain in the database.
  1547. Removal is based upon the file date represented by the entry, NOT the date the
  1548. file entry was made into the database; these are not one and the same. In the
  1549. example above, all records for files older than 60 months (5 years) will be
  1550. removed from the database. As a protective measure, ULPDB will not perform a
  1551. purge if the value specified is less than 6 months.
  1552.  
  1553.  
  1554. ┌──────────────────────────┐
  1555. │  11. BBS Ads and ULPADS  │
  1556. └──────────────────────────┘
  1557.  
  1558. The ULP system includes a BBS ad removal feature based on CRC-32 calculation of
  1559. the file contents and other data. In this fashion, ULP can detect a known ad
  1560. file despite the file name and date.
  1561.  
  1562. In order for sysops to be able to 'keep up' with new ads produced by the weenie
  1563. sysops who insert the @!&*#%$ things, I have included a utility called ULPADS
  1564. that can scan a BBS ad file, and update the BBS ads with it's information.
  1565. Don't worry about duplication, as part of the process is to purge duplicate BBS
  1566. ad info. The command-line syntax for the ULPADS.EXE program is simply:
  1567.  
  1568.     ULPADS -Ddatabase.ad -Fbbs.ad
  1569.  
  1570. where 'database.ad' is the full path and filename for the BBS ads database, and
  1571. 'bbs.ad' is the path and filename for the BBS ad file to be added to the ads
  1572. database.
  1573.  
  1574. If you have a subdirectory full of BBS ads, the following batch file provided
  1575. by Ian Singer may be of help:
  1576.  
  1577.     rem DELADS.BAT
  1578.     rem this batch file written by Ian Singer 1 Jul 92 to take all
  1579.     rem the bbs ads in c:\ulp\ad and run them against the database
  1580.     rem in c:\ulp
  1581.     rem
  1582.     for %%f in (c:\ulp\ad\*.*) do ULPADS -Dc:\ulp\ulpads.db -F%%f
  1583.  
  1584. I would greatly appreciate your uploading of any new BBS ad files that you may
  1585. collect over time to my BBS so I can update the master listing that I include
  1586. with the ULP distribution archive. Please refer to the top of this document for
  1587. my BBS number.
  1588.  
  1589. The latest version of my BBS ads database is included in the distribution
  1590. archive. In order to add whatever new BBS ads information that may be
  1591. contained, you can merge the two BBS databases:
  1592.  
  1593.     ULPADS -Dmaster.db -Mother.db
  1594.  
  1595. where 'master.db' is the full path and filename for the master (your) BBS ads
  1596. database, and 'other.db' is the path and filename for the other BBS ads
  1597. datatbase to be merged with the master ads database.
  1598.  
  1599.  
  1600. ┌───────────────┐
  1601. │  12. Support  │
  1602. └───────────────┘
  1603.  
  1604. If you require support for ULP, I can be contacted by any of the following
  1605. means:
  1606.  
  1607.     ∙ Fidonet netmail (node:  1:151/106)
  1608.     ∙ Internet private mail to "stacy.smith@cencore.com"
  1609.     ∙ Fidonet, ILink and Intelec PCBoard and Sysops conferences
  1610.     ∙ My Support conference (#2 on my BBS) which is linked to the Salt Air
  1611.       (PCBoard home system) ULP Support conference, as well as the Intelec,
  1612.       SmartNet and CompuLink networks' ULP Support conferences.
  1613.     ∙ The ILink ULP Support conference (separate and distinct, #3 on my BBS).
  1614.     ∙ The RIME ULP Support conference (separate and distinct).
  1615.  
  1616.  
  1617. ┌─────────────────────────┐
  1618. │  13. The Future of ULP  │
  1619. └─────────────────────────┘
  1620.  
  1621. ULP will be supported as long as I'm in the BBSing business (which will be
  1622. quite a while...once it's in your blood, you can never shake it <grin>). The
  1623. ULP system will be rapidly expanding it's features so it will be your first
  1624. choice in BBS upload processors. Some current plans:
  1625.  
  1626.       ∙ Add the ability to preprocess files prior to file checking them;
  1627.         for example, decompress executables that have been PKLite'd.
  1628.       ∙ Support other BBS software directory listing formats.
  1629.  
  1630. If you have any other suggestions, or want other archivers supported, please
  1631. contact me via Email, U.S. snail-mail or on my BBS at the number at the top of
  1632. this document.
  1633.  
  1634. Thanks for giving ULP a try!
  1635.  
  1636.  
  1637. ┌────────────────────────────────┐
  1638. │  Appendix A:  DOS Errorlevels  │
  1639. └────────────────────────────────┘
  1640.  
  1641. The errorlevels returned to DOS by the ULP system programs are consistent
  1642. among all of the programs (primarily with the error conditions); the following
  1643. is a list of the errorlevels than can be returned by the ULP programs, along
  1644. with which programs return the codes:
  1645.  
  1646.     0       Successful execution (ULPTEST, ULPDB, ULPADS)
  1647.     0       Successful execution, archives were processed (ULP)
  1648.     1       Successful execution, nothing to do (ULP)
  1649.     1       Unknown archive format (ULPTEST)
  1650.     2       DOS reserved keyword found in archive (ULPTEST)
  1651.     3       Error unpacking archive (archive integrity) (ULPTEST)
  1652.     4       Error file checking archive files (virus, etc.) (ULPTEST)
  1653.     5       Error duplicate checking archive files (ULPTEST)
  1654.     7       Age limit exceeded by archive files (ULPTEST)
  1655.     8       Encrypted file found in archive files (ULPTEST)
  1656.     9       Bad GIF file (ULPTEST)
  1657.     10      Unacceptable GIF resolution (ULPTEST)
  1658.     11      GIF compressed with GIFLITE (ULPTEST)
  1659.     12      Unable to create work space (ULPTEST)
  1660.     99      Help screen (executing a program with no or an insufficient number
  1661.             of arguments) (All)
  1662.     100     Could not close all open files (ULP, ULPTEST, ULPDB)
  1663.     101     Unknown command line parameter (All)
  1664.     102     Config file not found (All)
  1665.     103     Invalid configuration file format; use UPDATE.EXE to update (ULP,
  1666.             ULPTEST, ULPDB)
  1667.     104     Excessive number of command line parameters defined for
  1668.             file checker (maximum number of parameters is 13) (ULP, ULPTEST)
  1669.     105     Excessive number of command line parameters defined for archiver
  1670.             (max is 13) (ULP, ULPTEST, ULPDB)
  1671.     106     Excessive number of words defined in archive information line (max
  1672.             is 13) (ULP, ULPTEST)
  1673.     107     No primary archiver defined (ULP)
  1674.     108     Invalid disk buffer size (All)
  1675.     109     Upload directory list file(s) not found (ULP, ULPTEST)
  1676.     110     Unable to allocate heap memory (All)
  1677.     111     Unable to open or lock disk logging file (ULP, ULPTEST, ULPDB)
  1678.     112     Invalid registration code or attempting to run 286 or 386 versions
  1679.             without registering (ULP, ULPTEST, ULPDB)
  1680.     113     Unable to open/lock duplication database file(s) (ULP, ULPTEST,
  1681.             ULPDB)
  1682.     114     Unable to open BBS ads database file (ULP, ULPADS)
  1683.     115     Invalid filename provided by user on command-line (ULP, ULPTEST)
  1684.     116     Invalid path provided by user on command-line (ULP, ULPDB)
  1685.     117     Invalid or no node number (valid values are 1 to 256) (ULPTEST)
  1686.     118     Internal duplication database usage not enabled (configuration
  1687.             file parameter is set to 'N' or 'Z') (ULPDB)
  1688.     120     Invalid or old database format (All)
  1689.     121     Unable to process com port/invalid port parameter (ULPTEST)
  1690.     122     Unable to access PCBOARD.SYS (ULPTEST)
  1691.     123     Duplication database failed validation test (ULPDB)
  1692.     124     ZDCS/ULP interface program failure (ULPTEST)
  1693.     125     Unable to open privileged user list file (ULPTEST)
  1694.     126     Unable to determine comm port information (ULPTEST)
  1695.     200     Undefined error (internal to ULP system program(s))
  1696.  
  1697.  
  1698. ┌────────────────────────────────┐
  1699. │  Appendix B:  Acknowlegements  │
  1700. └────────────────────────────────┘
  1701.  
  1702. The problem of automatically recognizing duplicate files on large bulletin
  1703. board systems, independent of filename, was originally solved by Dr. Frederick
  1704. W. Kantor (founder of Information Mechanics and author of FWKCS(TM)
  1705. Contents_Signature System), who came up with the elegant solution of using both
  1706. the 32_bit CRC and the uncompressed file length together to make a
  1707. "contents_signature" for each file. Dr. Kantor's experimental data has shown a
  1708. typical pairwise error rate of less than one part in ten trillion using this
  1709. technology.
  1710.  
  1711.  
  1712. ┌─────────────────────────────────────┐
  1713. │  Appendix C:  Command Line Summary  │
  1714. └─────────────────────────────────────┘
  1715.  
  1716. ULP.EXE command-line syntax:
  1717.  
  1718.     ULP -Cd:\path\config.ext [-I] [-O] [-Rd:\path\] [-Md:\path\]
  1719.  
  1720.     -C  complete path and filename of the configuration file.
  1721.     -I  initialize the process data file. (Optional)
  1722.     -O  processes all archives, regardless of duplication or age limits,
  1723.         including previously processed archives with errors. (Optional)
  1724.     -R  retests all archives found in the directory specified for the
  1725.         purpose of re-checking archives for viruses, etc.. (Optional)
  1726.     -M  performs a mass conversion of all archives found in the directory
  1727.         specified to your default archive format. (Optional)
  1728.  
  1729. ULPTEST.EXE command-line syntax:
  1730.  
  1731.     ULPTEST -Cd:\path\cfg.ext -Fd:\path\archive.ext -Mmode [-Dd:\path\desc.ext]
  1732.         [-Pd:\path\] [-N#] [-L] [-B#] [-I#] [-Annn] [-Hmethod] [-X#] [-Gmode]
  1733.  
  1734.     -C  complete path and filename of the configuration file.
  1735.     -F  complete path and filename of the archive file to be tested.
  1736.     -M  processing mode [Upload/Test/Attach].
  1737.     -D  complete path and filename of the upload description file. (Optional)
  1738.     -P  complete path to the BBS starting directory. (Optional)
  1739.     -N  BBS node number executing ULPTEST. (Optional)
  1740.     -L  force local mode without comm I/O. (Optional)
  1741.     -B  COM port computer to modem (DTE) baud rate. (Optional)
  1742.     -I  COM port interrupt number. (Optional)
  1743.     -A  COM port base address (in hex). (Optional)
  1744.     -H  COM port handshaking method [Hardware/Software/Both]. (Optional)
  1745.     -X  FOSSIL port number. (Optional)
  1746.     -G  ANSI graphics toggle [Yes/No]. (Optional)
  1747.  
  1748. ULPDB.EXE command-line syntax:
  1749.  
  1750.     ULPDB -Cd:\path\config.ext [-Ad:\path\] [-U] [-Md:\path\database.ext]
  1751.         [-Id:\path\foreign.ext] [-S] [-P#] [-Vd:\path\archive.ext]
  1752.  
  1753.     -C  complete path and filename of the configuration file.
  1754.     -A  adds files located in the directory specified to the database
  1755.         file. List files supported by prefixing with a @ or !. (Optional)
  1756.     -U  forces unpacking of all archives when adding files. (Optional)
  1757.     -M  complete path and filename of a second database file to be merged
  1758.         with the master database file. (Optional)
  1759.     -I  complete path and filename of the foreign format database file to
  1760.         be imported into the master database file. (Optional)
  1761.     -S  compiles, sorts and indexes the database. (Optional)
  1762.     -P  age in months for purging database entries. (Optional)
  1763.     -V  complete path and filename of the archive to be viewed. (Optional)
  1764.  
  1765. ULPSM.EXE command-line syntax:
  1766.  
  1767.     ULPSM -Cd:\path\config.cfg [-Q]
  1768.  
  1769.     -C  complete path and filename of the configuration file.
  1770.     -Q  quiets beep when an error is detected. (Optional)
  1771.  
  1772. ULPADS.EXE command-line syntax:
  1773.  
  1774.     ULPADS -Dd:\path\database.ext [-Fd:\path\bbs.ad] [-Md:\path\database.ext]
  1775.  
  1776.     -D  complete path and filename of the master BBS ads database file.
  1777.     -F  complete path and filename of the ad file to be added to the BBS
  1778.         ads database. (Optional)
  1779.     -M  complete path and filename of a second BBS ad database to be merged
  1780.         with the master ads database. (Optional)
  1781.