summaryrefslogtreecommitdiff
path: root/contrib/isn/ISSN.h
blob: aeafb0c3c7dceebd1fc83ffdf561d9dc421a6e4e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
/* 
 * ISSN.h
 *	  PostgreSQL type definitions for ISNs (ISBN, ISMN, ISSN, EAN13, UPC)
 *
 * Information recompiled by Kronuz on November 12, 2004
 * http://www.issn.org/
 *
 * IDENTIFICATION
 *	  $PostgreSQL: pgsql/contrib/isn/ISSN.h,v 1.1 2006/09/09 04:07:52 tgl Exp $
 *
 * 1144-875X <=> 1144875(X) <=> 1144875 <=> (977)1144875 <=> 9771144875(00) <=> 977114487500(7) <=> 977-1144-875-00-7
 *
 * 
 * ISSN         1   1   4    4    8    7    5
 * Weight       8   7   6    5    4    3    2 
 * Product      8 + 7 + 24 + 20 + 32 + 21 + 10 = 122
 *              122 / 11 = 11 remainder 1
 * Check digit  11 - 1 = 10 = X
 * => 1144-875X
 * 
 * ISSN         9   7    7   1   1   4    4   8    7   5    0   0
 * Weight       1   3    1   3   1   3    1   3    1   3    1   3
 * Product      9 + 21 + 7 + 3 + 1 + 12 + 4 + 24 + 7 + 15 + 0 + 0 = 103
 *              103 / 10 = 10 remainder 3
 * Check digit  10 - 3 = 7
 * => 977-1144875-00-7 ??  <- suplemental number (number of the week, month, etc.)
 *                ^^ 00 for non-daily publications (01=Monday, 02=Tuesday, ...)
 *
 * The hyphenation is always in after the four digits of the ISSN code.
 *
 */

/* where the digit set begins, and how many of them are in the table */
const unsigned ISSN_index[10][2] = {
	{0,		1},
	{0,		1},
	{0,		1},
	{0,		1},
	{0,		1},
	{0,		1},
	{0,		1},
	{0,		1},
	{0,		1},
	{0,		1},
};
const char *ISSN_range[][2] = {
	{"0000-000", "9999-999"},
	{NULL, NULL}
};