Tillbaka till svenska Fidonet
English   Information   Debug  
FIDONEWS_OLD4   0/37224
FIDO_SYSOP   12847
FIDO_UTIL   0/180
FILEFIND   0/209
FILEGATE   0/212
FILM   0/18
FNEWS_PUBLISH   4208
FN_SYSOP   41525
FN_SYSOP_OLD1   71952
FTP_FIDO   0/2
FTSC_PUBLIC   0/13587
FUNNY   0/4886
GENEALOGY.EUR   0/71
GET_INFO   105
GOLDED   0/408
HAM   0/16054
HOLYSMOKE   0/6791
HOT_SITES   0/1
HTMLEDIT   0/71
HUB203   466
HUB_100   264
HUB_400   39
HUMOR   0/29
IC   0/2851
INTERNET   0/424
INTERUSER   0/3
IP_CONNECT   719
JAMNNTPD   0/233
JAMTLAND   0/47
KATTY_KORNER   0/41
LAN   0/16
LINUX-USER   0/19
LINUXHELP   0/1155
LINUX   0/22013
LINUX_BBS   0/957
mail   18.68
mail_fore_ok   249
MENSA   0/341
MODERATOR   0/102
MONTE   0/992
MOSCOW_OKLAHOMA   0/1245
MUFFIN   0/783
MUSIC   0/321
N203_STAT   902
N203_SYSCHAT   313
NET203   321
NET204   69
NET_DEV   0/10
NORD.ADMIN   0/101
NORD.CHAT   0/2572
NORD.FIDONET   189
NORD.HARDWARE   0/28
NORD.KULTUR   0/114
NORD.PROG   0/32
NORD.SOFTWARE   0/88
NORD.TEKNIK   0/58
NORD   0/453
OCCULT_CHAT   0/93
OS2BBS   0/787
OS2DOSBBS   0/580
OS2HW   0/42
OS2INET   0/37
OS2LAN   0/134
OS2PROG   0/36
OS2REXX   0/113
OS2USER-L   207
OS2   0/4786
OSDEBATE   0/18996
PASCAL   0/490
PERL   0/457
PHP   0/45
POINTS   0/405
POLITICS   0/29554
POL_INC   0/14731
PSION   103
R20_ADMIN   1117
R20_AMATORRADIO   0/2
R20_BEST_OF_FIDONET   13
R20_CHAT   0/893
R20_DEPP   0/3
R20_DEV   399
R20_ECHO2   1379
R20_ECHOPRES   0/35
R20_ESTAT   0/719
R20_FIDONETPROG...
...RAM.MYPOINT
  0/2
R20_FIDONETPROGRAM   0/22
R20_FIDONET   0/248
R20_FILEFIND   0/24
R20_FILEFOUND   0/22
R20_HIFI   0/3
R20_INFO2   2852
R20_INTERNET   0/12940
R20_INTRESSE   0/60
R20_INTR_KOM   0/99
R20_KANDIDAT.CHAT   42
R20_KANDIDAT   28
R20_KOM_DEV   112
R20_KONTROLL   0/13078
R20_KORSET   0/18
R20_LOKALTRAFIK   0/24
R20_MODERATOR   0/1852
R20_NC   76
R20_NET200   245
R20_NETWORK.OTH...
...ERNETS
  0/13
R20_OPERATIVSYS...
...TEM.LINUX
  0/44
R20_PROGRAMVAROR   0/1
R20_REC2NEC   534
R20_SFOSM   0/340
R20_SF   0/108
R20_SPRAK.ENGLISH   0/1
R20_SQUISH   107
R20_TEST   2
R20_WORST_OF_FIDONET   12
RAR   0/9
RA_MULTI   106
RA_UTIL   0/162
REGCON.EUR   0/2056
REGCON   0/13
SCIENCE   0/1206
SF   0/239
SHAREWARE_SUPPORT   0/5146
SHAREWRE   0/14
SIMPSONS   0/169
STATS_OLD1   0/2539.065
STATS_OLD2   0/2530
STATS_OLD3   0/2395.095
STATS_OLD4   0/1692.25
SURVIVOR   0/495
SYSOPS_CORNER   0/3
SYSOP   0/84
TAGLINES   0/112
TEAMOS2   0/4530
TECH   0/2617
TEST.444   0/105
TRAPDOOR   0/19
TREK   0/755
TUB   0/290
UFO   0/40
UNIX   0/1316
USA_EURLINK   0/102
USR_MODEMS   0/1
VATICAN   0/2740
VIETNAM_VETS   0/14
VIRUS   0/378
VIRUS_INFO   0/201
VISUAL_BASIC   0/473
WHITEHOUSE   0/5187
WIN2000   0/101
WIN32   0/30
WIN95   0/4277
WIN95_OLD1   0/70272
WINDOWS   0/1517
WWB_SYSOP   0/419
WWB_TECH   0/810
ZCC-PUBLIC   0/1
ZEC   4

 
4DOS   0/134
ABORTION   0/7
ALASKA_CHAT   0/506
ALLFIX_FILE   0/1313
ALLFIX_FILE_OLD1   0/7997
ALT_DOS   0/152
AMATEUR_RADIO   0/1039
AMIGASALE   0/14
AMIGA   0/331
AMIGA_INT   0/1
AMIGA_PROG   0/20
AMIGA_SYSOP   0/26
ANIME   0/15
ARGUS   0/924
ASCII_ART   0/340
ASIAN_LINK   0/651
ASTRONOMY   0/417
AUDIO   0/92
AUTOMOBILE_RACING   0/105
BABYLON5   0/17862
BAG   135
BATPOWER   0/361
BBBS.ENGLISH   0/382
BBSLAW   0/109
BBS_ADS   0/5290
BBS_INTERNET   0/507
BIBLE   0/3563
BINKD   0/1119
BINKLEY   0/215
BLUEWAVE   0/2173
CABLE_MODEMS   0/25
CBM   0/46
CDRECORD   0/66
CDROM   0/20
CLASSIC_COMPUTER   0/378
COMICS   0/15
CONSPRCY   0/899
COOKING   28827
COOKING_OLD1   0/24719
COOKING_OLD2   0/40862
COOKING_OLD3   0/37489
COOKING_OLD4   0/35496
COOKING_OLD5   9370
C_ECHO   0/189
C_PLUSPLUS   0/31
DIRTY_DOZEN   0/201
DOORGAMES   0/2031
DOS_INTERNET   0/196
duplikat   6000
ECHOLIST   0/18295
EC_SUPPORT   0/318
ELECTRONICS   0/359
ELEKTRONIK.GER   1534
ENET.LINGUISTIC   0/13
ENET.POLITICS   0/4
ENET.SOFT   0/11701
ENET.SYSOP   33810
ENET.TALKS   0/32
ENGLISH_TUTOR   0/2000
EVOLUTION   0/1335
FDECHO   0/217
FDN_ANNOUNCE   0/7068
FIDONEWS   23559
FIDONEWS_OLD1   0/49742
FIDONEWS_OLD2   0/35949
FIDONEWS_OLD3   0/30874
Möte FTSC_PUBLIC, 13587 texter
 lista första sista föregående nästa
Text 7919, 414 rader
Skriven 2015-11-08 23:05:07 av Michiel van der Vlist (2:280/5555)
Ärende: FSP-1039.001
====================
**********************************************************************
FTSC                             FIDONET TECHNICAL STANDARDS COMMITTEE
**********************************************************************

Publication:    FSP-1039
Revision:       1
Title:          TIC file format.
Authors:        Michiel van der Vlist, FTSC members.
Date:           2015-11-08
----------------------------------------------------------------------

Contents
--------
                1. Definitions
                2. TIC file system.
                   2.1 Introduction
                   2.2 The TIC file format
                   2.3 TIC Keywords
                3. CRC-32 Algorithm
                A. References
                B. History
----------------------------------------------------------------------

Status of this document
-----------------------

   This document is a FidoNet Standard Proposal (FSP).

   This document proposes a FidoNet standard for the FidoNet
   community.

   This document is released to the public domain, and may be used,
   copied or modified for any purpose whatever.


1. Definitions
--------------

   The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL
   NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL"
   in this document are to be interpreted as described in [FTA-1006].


2. The TIC file system
----------------------

2.1 Introduction
----------------

   The TIC file system is a way to distribute files via Fidonet
   technology. It is also called the file echo system in analogy
   with the echomail system used for messages.

   To distribute a file, it is always accompanied by a control
   file, called the TIC file. TIC files are created and processed
   by file processors. When a system that is configured for file
   processing receives a TIC file it calls the file processor.
   The file processor acts on the keywords in the TIC file and it
   may move the file to be distributed to dedicated directories
   and/or send it on to other nodes.

   The details of this process are beyond the scope of this document
   which is limited to the format of the TIC file.


2.2 TIC file format
-------------------

   A TIC file is a text file with a name in 8.3 DOS format with the
   extension .TIC. The name of the TIC file should be unique enough
   to ensure that systems receiving TIC files never have two TIC
   files with the same name in their inbound. How this is done is
   left to the implementation.

   The line separator is a CR,LF pair. It is recommended that
   applications reading TIC files can read TIC files that only use
   a LF or CR as line separator. Application must only write files
   with a CR,LF pair.

   Each line in a TIC file consists of a keyword followed by one or
   more parameters.

   Parameters can be a string of text, an FTN address in 4D or 5D
   format or a (hexadecimal) number.

   Keywords are case insensitive.

   Keywords are not position dependant with the exception of the
   the Path, Desc and Ldesc keywords. If there is more than one,
   they must be grouped and ordered.

   New implementations should be tolerant of unknown keywords. If a
   line with an unknown keyword is found in an incoming TIC file, the
   preferred  way of dealing with it is to pass the line "as is" to
   outgoing TIC files and optionally log the encounter.
   Existing software may or may not act in this preferred way.


2.3 TIC Keywords
----------------

   Area

     The tag of the area in which the file is to be distributed.

     Example: Area REGION28

     This is a required keyword.


   Areadesc

     A short description of the area. This may be used when auto-
     creating a new area.

     Example: Region28 nodelist segment.

     This is an optional keyword.


   Origin

     This keyword specifies the FTN address of the system that has
     hatched the file.

     Example:    Origin 2:28/0

     This is a required keyword.


   From

     This keyword specifies the FTN address of the system that has
     sent the file to be distributed and the accompanying TIC file.

     Example:   From 2:280/5555

     This is a required keyword


   To

     This keyword specifies the FTN address of the system where to
     send the file to be distributed and the accompanying TIC file.
     Some File processors (Allfix) only insert a line with this
     keyword when the file and the associated TIC file are to be
     file routed through a third sysem instead of being processed
     by a file processor on that system. Others always insert it.
     Note that the To keyword may cause problems when the TIC file
     is proecessed by software that does not recognise it and
     passes the line "as is" to other systems.

     Example:  To 292/854

     This is an optional keyword.


   File

     The name of the file to be distributed. The name must be in
     8x3 DOS format. If an Lfile keyword is also specified, the
     8x3 file name may be automatically derived from the long
     file name by the file processor hatching the file. The algorithm
     is left to the implementation.

     Example:  File REGION28.208

     This is a required keyword.


   Lfile

     The name of the file in long file format.

     Note that few file processors will recognise this Keyword.
     Your milage may vary when attempting to distribute files
     with long file names.

     Example: Lfile Longfilename.extension

     This is an optional keyword.


   Fullname

     This is an alias for Lfile. It is recommended that applications
     always use Lfile when writing TIC files but recognise Fullname
     as an alias when reading TIC files.


   Size

     The size of the file in bytes.

     Example: Size 5000

     This is an optional keyword.


   Date

    The date and time the file was created in Unix form.

    Example: Date 1415567298

    This is an optional keyword.


   Desc

     A one line description of the file to be distributed.

     Example: Desc Region 28 nodelist segment for day 208

     This is an optional keyword


   Ldesc

     This Keyword may occur more than once. If there is more than one
     they should be grouped together. Together they form a long
     description of the file to be distributed.

     Example: Ldesc This is a utility that everyone must have.
              Ldesc It beats all and everything you ever had.

     This is an optional keyword.


   Created

     This keyword identifies the software that created this TIC file.
     There is no rigid format for this Keyword.

     Example: Created by Mtick 1.4 beta 20070731, (c) 1995-2007,
             Michiel van der Vlist, PA0MMMV (2:280/5555)

     (Split over two lines in this document, one line in reality)

     This is an optional keyword.


   Magic

     This specifies the magic word that file request processors may
     use as an alias for the file to be requested.

     Example: Magic REGION28

     This is an optional keyword.


   Replaces

     This specifies that the file replaces one or more files that
     were sent previously. It is up to the receiving system if it
     honours this keyword.
     The wildcard characters '?' and '*' may be used with the usual
     meaning as in MS-DOS.
     Some tic processors do not support wild cards and use of
     wild cards with this keyword may cause unexpected results.


    Example: Replaces REGION28.???


     This is an optional keyword.


   Crc

     This keyword specifies the CRC-32 of the file to be distributed.
     The CRC an eight digit hex number, preferably written in upper
     case, but application should be able to handle CRC's written in
     lower case.

     Example: Crc B0A29EE6

     This is a required keyword.


   Path

     This specifies the node number and the date and time of a
     system that has processed the file.
     The time parameter is expressed as a unix style timestamp,
     optionally followed by the date and time in human readable
     form. Unix timestamp is UTC. Human readable format may be
     local time (including UTC offset) or UTC.

     File processors may add additional information. For example a
     signature identifying the software generating the path line.

     Example:  Path 2:2/20 1415567298 Sun Nov 9 21:08:18 2014 UTC

     Each system should add its own line to the TIC file. Path
     lines should be grouped and in order of processing.

     This is a required keyword.


   Seenby

     This lists the systems that have "seen" the file. It is
     similar to the seen-by in echomail messages, with the
     difference that it is one line per node number and the
     node numbers are 4D or 5D. The seenby information may be
     used for dupe prevention.

     Seenby lines should be grouped and may be sorted by node
     number. Application must be able to deal with unsorted
     seenby lines.


     Example:  Seenby 2:2/20
               Seenby 2:280/5003
               Seenby 2:280/5555
               Seenby 2:280/5555.1
               Seenby 2:292/854

     This is a required keyword.


   Pw

     This specifies the password agreed upon between the sysops of
     the link. There are no restrictions on the length and the
     allowed characters of the password, it is a matter of what the
     sending and receiving sysops agree. Most file processors however
     will only accept a maximum of eight characters and treat them as
     case insensitive.

     Example:  Pw PASSWORD

     Although it is not recommended to distribute files between
     systems without agreeing on a password, this keyword is optional.
     Technically it is possible to accept files without a password.



3. CRC-32 Algorithm
-------------------

    This paragraph was copied from FTS-1030.001 par 2.4
    The author is Tobias Ernst.


    The checksum algorithm that is used is CRC-32 following ITU-T's
    specifications. For further information refer to the literature
    list given below. The following pseudocode shows how to
    calculate such a checksum for a file of N bytes indexed from 0 to
    N-1 and stored in BUFFER. The XOR, AND and NOT logical
    operations are to be executed bit-wise. In C, for instance, XOR
    equals ^, AND equals &, and NOT equals ~.

    // CRC, I, J, K are unsigned integers of at least 32 bits.
    UNSIGNED LONG CRC, I, J, K

    // Preconditioning
    CRC = FFFFFFFF

    // Loop through all bytes in the file
    FOR J = 0 TO N-1
      K = (CRC XOR BYTE#J) & 000000FF  // (*)
      FOR I = 8 DOWNTO 1
         IF K AND 1 <> 0
           THEN K = (K SHR 1) XOR EDB88320
         ELSE
           K = K SHR 1
         ENDIF
      END FOR                          // (**)
      CRC = ((CRC SHR 8) AND 00FFFFFF) XOR K
    END FOR

    // Postconditioning: Flip all bits
    CRC = NOT CRC;

    Note that as in the line marked as (*), K can initially only get
    values in the range from 0 to 255. Therefore it is a good idea
    to replace the inner loop over I with a lookup table routine,
    i.E. generate a lookup table for the outcomes of K after the loop
    with initial values of K from 0 to 255, and then replace lines
    (*) up to and including (**) with something like

    K = LOOKUPTABLE [ (CRC XOR BYTE#J) XOR 000000FF ]

 Author: Tobias Ernst



A. References
-------------

    [FTA-1006]
           Key words to indicate requirement levels, Fidonet Technical
           Standards Committee administrative. FTA-1006.

    [FTA-1030]
           Binkp optional protocol extension CRC Checksum.


    [ITU-T V.42]
           International Telecommunications Union, Error-correcting
           Procedures for DCEs Using Asynchronous-to-Synchronous
           Conversion, ITU-T Recommendation V.42, 1994, Rev. 1.


B. History
----------
    Rev.1, 2015-11-08: First release.


--- GoldED+/W32-MSVC 1.1.5-b20130111
 * Origin: http://www.vlist.org (2:280/5555)