image_intensities 1.0.3 → 1.0.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (93) hide show
  1. checksums.yaml +4 -4
  2. data/ext/image_intensities/Makefile +73 -4
  3. data/ext/image_intensities/turbojpeg/cderror.h +137 -0
  4. data/ext/image_intensities/turbojpeg/cdjpeg.h +157 -0
  5. data/ext/image_intensities/turbojpeg/cmyk.h +61 -0
  6. data/ext/image_intensities/turbojpeg/jaricom.c +157 -0
  7. data/ext/image_intensities/turbojpeg/jcapimin.c +295 -0
  8. data/ext/image_intensities/turbojpeg/jcapistd.c +162 -0
  9. data/ext/image_intensities/turbojpeg/jcarith.c +932 -0
  10. data/ext/image_intensities/turbojpeg/jccoefct.c +449 -0
  11. data/ext/image_intensities/turbojpeg/jccolext.c +144 -0
  12. data/ext/image_intensities/turbojpeg/jccolor.c +710 -0
  13. data/ext/image_intensities/turbojpeg/jcdctmgr.c +721 -0
  14. data/ext/image_intensities/turbojpeg/jchuff.c +1096 -0
  15. data/ext/image_intensities/turbojpeg/jchuff.h +42 -0
  16. data/ext/image_intensities/turbojpeg/jcicc.c +105 -0
  17. data/ext/image_intensities/turbojpeg/jcinit.c +77 -0
  18. data/ext/image_intensities/turbojpeg/jcmainct.c +162 -0
  19. data/ext/image_intensities/turbojpeg/jcmarker.c +664 -0
  20. data/ext/image_intensities/turbojpeg/jcmaster.c +640 -0
  21. data/ext/image_intensities/turbojpeg/jcomapi.c +109 -0
  22. data/ext/image_intensities/turbojpeg/jconfig.h +73 -0
  23. data/ext/image_intensities/turbojpeg/jconfigint.h +31 -0
  24. data/ext/image_intensities/turbojpeg/jcparam.c +541 -0
  25. data/ext/image_intensities/turbojpeg/jcphuff.c +1105 -0
  26. data/ext/image_intensities/turbojpeg/jcprepct.c +351 -0
  27. data/ext/image_intensities/turbojpeg/jcsample.c +539 -0
  28. data/ext/image_intensities/turbojpeg/jctrans.c +400 -0
  29. data/ext/image_intensities/turbojpeg/jdapimin.c +407 -0
  30. data/ext/image_intensities/turbojpeg/jdapistd.c +639 -0
  31. data/ext/image_intensities/turbojpeg/jdarith.c +773 -0
  32. data/ext/image_intensities/turbojpeg/jdatadst-tj.c +203 -0
  33. data/ext/image_intensities/turbojpeg/jdatadst.c +293 -0
  34. data/ext/image_intensities/turbojpeg/jdatasrc-tj.c +194 -0
  35. data/ext/image_intensities/turbojpeg/jdatasrc.c +295 -0
  36. data/ext/image_intensities/turbojpeg/jdcoefct.c +692 -0
  37. data/ext/image_intensities/turbojpeg/jdcoefct.h +82 -0
  38. data/ext/image_intensities/turbojpeg/jdcol565.c +384 -0
  39. data/ext/image_intensities/turbojpeg/jdcolext.c +143 -0
  40. data/ext/image_intensities/turbojpeg/jdcolor.c +883 -0
  41. data/ext/image_intensities/turbojpeg/jdct.h +208 -0
  42. data/ext/image_intensities/turbojpeg/jddctmgr.c +352 -0
  43. data/ext/image_intensities/turbojpeg/jdhuff.c +831 -0
  44. data/ext/image_intensities/turbojpeg/jdhuff.h +238 -0
  45. data/ext/image_intensities/turbojpeg/jdicc.c +171 -0
  46. data/ext/image_intensities/turbojpeg/jdinput.c +408 -0
  47. data/ext/image_intensities/turbojpeg/jdmainct.c +460 -0
  48. data/ext/image_intensities/turbojpeg/jdmainct.h +71 -0
  49. data/ext/image_intensities/turbojpeg/jdmarker.c +1377 -0
  50. data/ext/image_intensities/turbojpeg/jdmaster.c +737 -0
  51. data/ext/image_intensities/turbojpeg/jdmaster.h +28 -0
  52. data/ext/image_intensities/turbojpeg/jdmerge.c +617 -0
  53. data/ext/image_intensities/turbojpeg/jdmrg565.c +354 -0
  54. data/ext/image_intensities/turbojpeg/jdmrgext.c +184 -0
  55. data/ext/image_intensities/turbojpeg/jdphuff.c +687 -0
  56. data/ext/image_intensities/turbojpeg/jdpostct.c +294 -0
  57. data/ext/image_intensities/turbojpeg/jdsample.c +518 -0
  58. data/ext/image_intensities/turbojpeg/jdsample.h +50 -0
  59. data/ext/image_intensities/turbojpeg/jdtrans.c +155 -0
  60. data/ext/image_intensities/turbojpeg/jerror.c +251 -0
  61. data/ext/image_intensities/turbojpeg/jfdctflt.c +169 -0
  62. data/ext/image_intensities/turbojpeg/jfdctfst.c +227 -0
  63. data/ext/image_intensities/turbojpeg/jfdctint.c +288 -0
  64. data/ext/image_intensities/turbojpeg/jidctflt.c +240 -0
  65. data/ext/image_intensities/turbojpeg/jidctfst.c +371 -0
  66. data/ext/image_intensities/turbojpeg/jidctint.c +2627 -0
  67. data/ext/image_intensities/turbojpeg/jidctred.c +409 -0
  68. data/ext/image_intensities/turbojpeg/jinclude.h +88 -0
  69. data/ext/image_intensities/turbojpeg/jmemmgr.c +1179 -0
  70. data/ext/image_intensities/turbojpeg/jmemnobs.c +115 -0
  71. data/ext/image_intensities/turbojpeg/jmemsys.h +178 -0
  72. data/ext/image_intensities/turbojpeg/jpeg_nbits_table.h +4098 -0
  73. data/ext/image_intensities/turbojpeg/jpegcomp.h +31 -0
  74. data/ext/image_intensities/turbojpeg/jquant1.c +859 -0
  75. data/ext/image_intensities/turbojpeg/jquant2.c +1285 -0
  76. data/ext/image_intensities/turbojpeg/jsimd.h +117 -0
  77. data/ext/image_intensities/turbojpeg/jsimd_none.c +418 -0
  78. data/ext/image_intensities/turbojpeg/jsimddct.h +70 -0
  79. data/ext/image_intensities/turbojpeg/jstdhuff.c +143 -0
  80. data/ext/image_intensities/turbojpeg/jutils.c +133 -0
  81. data/ext/image_intensities/turbojpeg/jversion.h +52 -0
  82. data/ext/image_intensities/turbojpeg/libturbojpeg.a +0 -0
  83. data/ext/image_intensities/turbojpeg/rdbmp.c +689 -0
  84. data/ext/image_intensities/turbojpeg/rdppm.c +766 -0
  85. data/ext/image_intensities/turbojpeg/tjutil.h +47 -0
  86. data/ext/image_intensities/turbojpeg/transupp.c +1628 -0
  87. data/ext/image_intensities/turbojpeg/transupp.h +210 -0
  88. data/ext/image_intensities/turbojpeg/turbojpeg.c +2150 -0
  89. data/ext/image_intensities/turbojpeg/wrbmp.c +558 -0
  90. data/ext/image_intensities/turbojpeg/wrppm.c +365 -0
  91. data/image_intensities.gemspec +1 -1
  92. data/lib/image_intensities/version.rb +1 -1
  93. metadata +91 -3
@@ -0,0 +1,143 @@
1
+ /*
2
+ * jstdhuff.c
3
+ *
4
+ * This file was part of the Independent JPEG Group's software:
5
+ * Copyright (C) 1991-1998, Thomas G. Lane.
6
+ * libjpeg-turbo Modifications:
7
+ * Copyright (C) 2013, D. R. Commander.
8
+ * For conditions of distribution and use, see the accompanying README.ijg
9
+ * file.
10
+ *
11
+ * This file contains routines to set the default Huffman tables, if they are
12
+ * not already set.
13
+ */
14
+
15
+ /*
16
+ * Huffman table setup routines
17
+ */
18
+
19
+ LOCAL(void)
20
+ add_huff_table(j_common_ptr cinfo, JHUFF_TBL **htblptr, const UINT8 *bits,
21
+ const UINT8 *val)
22
+ /* Define a Huffman table */
23
+ {
24
+ int nsymbols, len;
25
+
26
+ if (*htblptr == NULL)
27
+ *htblptr = jpeg_alloc_huff_table(cinfo);
28
+ else
29
+ return;
30
+
31
+ /* Copy the number-of-symbols-of-each-code-length counts */
32
+ MEMCOPY((*htblptr)->bits, bits, sizeof((*htblptr)->bits));
33
+
34
+ /* Validate the counts. We do this here mainly so we can copy the right
35
+ * number of symbols from the val[] array, without risking marching off
36
+ * the end of memory. jchuff.c will do a more thorough test later.
37
+ */
38
+ nsymbols = 0;
39
+ for (len = 1; len <= 16; len++)
40
+ nsymbols += bits[len];
41
+ if (nsymbols < 1 || nsymbols > 256)
42
+ ERREXIT(cinfo, JERR_BAD_HUFF_TABLE);
43
+
44
+ MEMCOPY((*htblptr)->huffval, val, nsymbols * sizeof(UINT8));
45
+ MEMZERO(&((*htblptr)->huffval[nsymbols]), (256 - nsymbols) * sizeof(UINT8));
46
+
47
+ /* Initialize sent_table FALSE so table will be written to JPEG file. */
48
+ (*htblptr)->sent_table = FALSE;
49
+ }
50
+
51
+
52
+ LOCAL(void)
53
+ std_huff_tables(j_common_ptr cinfo)
54
+ /* Set up the standard Huffman tables (cf. JPEG standard section K.3) */
55
+ /* IMPORTANT: these are only valid for 8-bit data precision! */
56
+ {
57
+ JHUFF_TBL **dc_huff_tbl_ptrs, **ac_huff_tbl_ptrs;
58
+
59
+ static const UINT8 bits_dc_luminance[17] = {
60
+ /* 0-base */ 0, 0, 1, 5, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0
61
+ };
62
+ static const UINT8 val_dc_luminance[] = {
63
+ 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11
64
+ };
65
+
66
+ static const UINT8 bits_dc_chrominance[17] = {
67
+ /* 0-base */ 0, 0, 3, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0
68
+ };
69
+ static const UINT8 val_dc_chrominance[] = {
70
+ 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11
71
+ };
72
+
73
+ static const UINT8 bits_ac_luminance[17] = {
74
+ /* 0-base */ 0, 0, 2, 1, 3, 3, 2, 4, 3, 5, 5, 4, 4, 0, 0, 1, 0x7d
75
+ };
76
+ static const UINT8 val_ac_luminance[] = {
77
+ 0x01, 0x02, 0x03, 0x00, 0x04, 0x11, 0x05, 0x12,
78
+ 0x21, 0x31, 0x41, 0x06, 0x13, 0x51, 0x61, 0x07,
79
+ 0x22, 0x71, 0x14, 0x32, 0x81, 0x91, 0xa1, 0x08,
80
+ 0x23, 0x42, 0xb1, 0xc1, 0x15, 0x52, 0xd1, 0xf0,
81
+ 0x24, 0x33, 0x62, 0x72, 0x82, 0x09, 0x0a, 0x16,
82
+ 0x17, 0x18, 0x19, 0x1a, 0x25, 0x26, 0x27, 0x28,
83
+ 0x29, 0x2a, 0x34, 0x35, 0x36, 0x37, 0x38, 0x39,
84
+ 0x3a, 0x43, 0x44, 0x45, 0x46, 0x47, 0x48, 0x49,
85
+ 0x4a, 0x53, 0x54, 0x55, 0x56, 0x57, 0x58, 0x59,
86
+ 0x5a, 0x63, 0x64, 0x65, 0x66, 0x67, 0x68, 0x69,
87
+ 0x6a, 0x73, 0x74, 0x75, 0x76, 0x77, 0x78, 0x79,
88
+ 0x7a, 0x83, 0x84, 0x85, 0x86, 0x87, 0x88, 0x89,
89
+ 0x8a, 0x92, 0x93, 0x94, 0x95, 0x96, 0x97, 0x98,
90
+ 0x99, 0x9a, 0xa2, 0xa3, 0xa4, 0xa5, 0xa6, 0xa7,
91
+ 0xa8, 0xa9, 0xaa, 0xb2, 0xb3, 0xb4, 0xb5, 0xb6,
92
+ 0xb7, 0xb8, 0xb9, 0xba, 0xc2, 0xc3, 0xc4, 0xc5,
93
+ 0xc6, 0xc7, 0xc8, 0xc9, 0xca, 0xd2, 0xd3, 0xd4,
94
+ 0xd5, 0xd6, 0xd7, 0xd8, 0xd9, 0xda, 0xe1, 0xe2,
95
+ 0xe3, 0xe4, 0xe5, 0xe6, 0xe7, 0xe8, 0xe9, 0xea,
96
+ 0xf1, 0xf2, 0xf3, 0xf4, 0xf5, 0xf6, 0xf7, 0xf8,
97
+ 0xf9, 0xfa
98
+ };
99
+
100
+ static const UINT8 bits_ac_chrominance[17] = {
101
+ /* 0-base */ 0, 0, 2, 1, 2, 4, 4, 3, 4, 7, 5, 4, 4, 0, 1, 2, 0x77
102
+ };
103
+ static const UINT8 val_ac_chrominance[] = {
104
+ 0x00, 0x01, 0x02, 0x03, 0x11, 0x04, 0x05, 0x21,
105
+ 0x31, 0x06, 0x12, 0x41, 0x51, 0x07, 0x61, 0x71,
106
+ 0x13, 0x22, 0x32, 0x81, 0x08, 0x14, 0x42, 0x91,
107
+ 0xa1, 0xb1, 0xc1, 0x09, 0x23, 0x33, 0x52, 0xf0,
108
+ 0x15, 0x62, 0x72, 0xd1, 0x0a, 0x16, 0x24, 0x34,
109
+ 0xe1, 0x25, 0xf1, 0x17, 0x18, 0x19, 0x1a, 0x26,
110
+ 0x27, 0x28, 0x29, 0x2a, 0x35, 0x36, 0x37, 0x38,
111
+ 0x39, 0x3a, 0x43, 0x44, 0x45, 0x46, 0x47, 0x48,
112
+ 0x49, 0x4a, 0x53, 0x54, 0x55, 0x56, 0x57, 0x58,
113
+ 0x59, 0x5a, 0x63, 0x64, 0x65, 0x66, 0x67, 0x68,
114
+ 0x69, 0x6a, 0x73, 0x74, 0x75, 0x76, 0x77, 0x78,
115
+ 0x79, 0x7a, 0x82, 0x83, 0x84, 0x85, 0x86, 0x87,
116
+ 0x88, 0x89, 0x8a, 0x92, 0x93, 0x94, 0x95, 0x96,
117
+ 0x97, 0x98, 0x99, 0x9a, 0xa2, 0xa3, 0xa4, 0xa5,
118
+ 0xa6, 0xa7, 0xa8, 0xa9, 0xaa, 0xb2, 0xb3, 0xb4,
119
+ 0xb5, 0xb6, 0xb7, 0xb8, 0xb9, 0xba, 0xc2, 0xc3,
120
+ 0xc4, 0xc5, 0xc6, 0xc7, 0xc8, 0xc9, 0xca, 0xd2,
121
+ 0xd3, 0xd4, 0xd5, 0xd6, 0xd7, 0xd8, 0xd9, 0xda,
122
+ 0xe2, 0xe3, 0xe4, 0xe5, 0xe6, 0xe7, 0xe8, 0xe9,
123
+ 0xea, 0xf2, 0xf3, 0xf4, 0xf5, 0xf6, 0xf7, 0xf8,
124
+ 0xf9, 0xfa
125
+ };
126
+
127
+ if (cinfo->is_decompressor) {
128
+ dc_huff_tbl_ptrs = ((j_decompress_ptr)cinfo)->dc_huff_tbl_ptrs;
129
+ ac_huff_tbl_ptrs = ((j_decompress_ptr)cinfo)->ac_huff_tbl_ptrs;
130
+ } else {
131
+ dc_huff_tbl_ptrs = ((j_compress_ptr)cinfo)->dc_huff_tbl_ptrs;
132
+ ac_huff_tbl_ptrs = ((j_compress_ptr)cinfo)->ac_huff_tbl_ptrs;
133
+ }
134
+
135
+ add_huff_table(cinfo, &dc_huff_tbl_ptrs[0], bits_dc_luminance,
136
+ val_dc_luminance);
137
+ add_huff_table(cinfo, &ac_huff_tbl_ptrs[0], bits_ac_luminance,
138
+ val_ac_luminance);
139
+ add_huff_table(cinfo, &dc_huff_tbl_ptrs[1], bits_dc_chrominance,
140
+ val_dc_chrominance);
141
+ add_huff_table(cinfo, &ac_huff_tbl_ptrs[1], bits_ac_chrominance,
142
+ val_ac_chrominance);
143
+ }
@@ -0,0 +1,133 @@
1
+ /*
2
+ * jutils.c
3
+ *
4
+ * This file was part of the Independent JPEG Group's software:
5
+ * Copyright (C) 1991-1996, Thomas G. Lane.
6
+ * It was modified by The libjpeg-turbo Project to include only code
7
+ * relevant to libjpeg-turbo.
8
+ * For conditions of distribution and use, see the accompanying README.ijg
9
+ * file.
10
+ *
11
+ * This file contains tables and miscellaneous utility routines needed
12
+ * for both compression and decompression.
13
+ * Note we prefix all global names with "j" to minimize conflicts with
14
+ * a surrounding application.
15
+ */
16
+
17
+ #define JPEG_INTERNALS
18
+ #include "jinclude.h"
19
+ #include "jpeglib.h"
20
+
21
+
22
+ /*
23
+ * jpeg_zigzag_order[i] is the zigzag-order position of the i'th element
24
+ * of a DCT block read in natural order (left to right, top to bottom).
25
+ */
26
+
27
+ #if 0 /* This table is not actually needed in v6a */
28
+
29
+ const int jpeg_zigzag_order[DCTSIZE2] = {
30
+ 0, 1, 5, 6, 14, 15, 27, 28,
31
+ 2, 4, 7, 13, 16, 26, 29, 42,
32
+ 3, 8, 12, 17, 25, 30, 41, 43,
33
+ 9, 11, 18, 24, 31, 40, 44, 53,
34
+ 10, 19, 23, 32, 39, 45, 52, 54,
35
+ 20, 22, 33, 38, 46, 51, 55, 60,
36
+ 21, 34, 37, 47, 50, 56, 59, 61,
37
+ 35, 36, 48, 49, 57, 58, 62, 63
38
+ };
39
+
40
+ #endif
41
+
42
+ /*
43
+ * jpeg_natural_order[i] is the natural-order position of the i'th element
44
+ * of zigzag order.
45
+ *
46
+ * When reading corrupted data, the Huffman decoders could attempt
47
+ * to reference an entry beyond the end of this array (if the decoded
48
+ * zero run length reaches past the end of the block). To prevent
49
+ * wild stores without adding an inner-loop test, we put some extra
50
+ * "63"s after the real entries. This will cause the extra coefficient
51
+ * to be stored in location 63 of the block, not somewhere random.
52
+ * The worst case would be a run-length of 15, which means we need 16
53
+ * fake entries.
54
+ */
55
+
56
+ const int jpeg_natural_order[DCTSIZE2 + 16] = {
57
+ 0, 1, 8, 16, 9, 2, 3, 10,
58
+ 17, 24, 32, 25, 18, 11, 4, 5,
59
+ 12, 19, 26, 33, 40, 48, 41, 34,
60
+ 27, 20, 13, 6, 7, 14, 21, 28,
61
+ 35, 42, 49, 56, 57, 50, 43, 36,
62
+ 29, 22, 15, 23, 30, 37, 44, 51,
63
+ 58, 59, 52, 45, 38, 31, 39, 46,
64
+ 53, 60, 61, 54, 47, 55, 62, 63,
65
+ 63, 63, 63, 63, 63, 63, 63, 63, /* extra entries for safety in decoder */
66
+ 63, 63, 63, 63, 63, 63, 63, 63
67
+ };
68
+
69
+
70
+ /*
71
+ * Arithmetic utilities
72
+ */
73
+
74
+ GLOBAL(long)
75
+ jdiv_round_up(long a, long b)
76
+ /* Compute a/b rounded up to next integer, ie, ceil(a/b) */
77
+ /* Assumes a >= 0, b > 0 */
78
+ {
79
+ return (a + b - 1L) / b;
80
+ }
81
+
82
+
83
+ GLOBAL(long)
84
+ jround_up(long a, long b)
85
+ /* Compute a rounded up to next multiple of b, ie, ceil(a/b)*b */
86
+ /* Assumes a >= 0, b > 0 */
87
+ {
88
+ a += b - 1L;
89
+ return a - (a % b);
90
+ }
91
+
92
+
93
+ GLOBAL(void)
94
+ jcopy_sample_rows(JSAMPARRAY input_array, int source_row,
95
+ JSAMPARRAY output_array, int dest_row, int num_rows,
96
+ JDIMENSION num_cols)
97
+ /* Copy some rows of samples from one place to another.
98
+ * num_rows rows are copied from input_array[source_row++]
99
+ * to output_array[dest_row++]; these areas may overlap for duplication.
100
+ * The source and destination arrays must be at least as wide as num_cols.
101
+ */
102
+ {
103
+ register JSAMPROW inptr, outptr;
104
+ register size_t count = (size_t)(num_cols * sizeof(JSAMPLE));
105
+ register int row;
106
+
107
+ input_array += source_row;
108
+ output_array += dest_row;
109
+
110
+ for (row = num_rows; row > 0; row--) {
111
+ inptr = *input_array++;
112
+ outptr = *output_array++;
113
+ MEMCOPY(outptr, inptr, count);
114
+ }
115
+ }
116
+
117
+
118
+ GLOBAL(void)
119
+ jcopy_block_row(JBLOCKROW input_row, JBLOCKROW output_row,
120
+ JDIMENSION num_blocks)
121
+ /* Copy a row of coefficient blocks from one place to another. */
122
+ {
123
+ MEMCOPY(output_row, input_row, num_blocks * (DCTSIZE2 * sizeof(JCOEF)));
124
+ }
125
+
126
+
127
+ GLOBAL(void)
128
+ jzero_far(void *target, size_t bytestozero)
129
+ /* Zero out a chunk of memory. */
130
+ /* This might be sample-array data, block-array data, or alloc_large data. */
131
+ {
132
+ MEMZERO(target, bytestozero);
133
+ }
@@ -0,0 +1,52 @@
1
+ /*
2
+ * jversion.h
3
+ *
4
+ * This file was part of the Independent JPEG Group's software:
5
+ * Copyright (C) 1991-2012, Thomas G. Lane, Guido Vollbeding.
6
+ * libjpeg-turbo Modifications:
7
+ * Copyright (C) 2010, 2012-2019, D. R. Commander.
8
+ * For conditions of distribution and use, see the accompanying README.ijg
9
+ * file.
10
+ *
11
+ * This file contains software version identification.
12
+ */
13
+
14
+
15
+ #if JPEG_LIB_VERSION >= 80
16
+
17
+ #define JVERSION "8d 15-Jan-2012"
18
+
19
+ #elif JPEG_LIB_VERSION >= 70
20
+
21
+ #define JVERSION "7 27-Jun-2009"
22
+
23
+ #else
24
+
25
+ #define JVERSION "6b 27-Mar-1998"
26
+
27
+ #endif
28
+
29
+ /*
30
+ * NOTE: It is our convention to place the authors in the following order:
31
+ * - libjpeg-turbo authors (2009-) in descending order of the date of their
32
+ * most recent contribution to the project, then in ascending order of the
33
+ * date of their first contribution to the project
34
+ * - Upstream authors in descending order of the date of the first inclusion of
35
+ * their code
36
+ */
37
+
38
+ #define JCOPYRIGHT \
39
+ "Copyright (C) 2009-2019 D. R. Commander\n" \
40
+ "Copyright (C) 2011-2016 Siarhei Siamashka\n" \
41
+ "Copyright (C) 2015-2016, 2018 Matthieu Darbois\n" \
42
+ "Copyright (C) 2015 Intel Corporation\n" \
43
+ "Copyright (C) 2015 Google, Inc.\n" \
44
+ "Copyright (C) 2013-2014 MIPS Technologies, Inc.\n" \
45
+ "Copyright (C) 2013 Linaro Limited\n" \
46
+ "Copyright (C) 2009-2011 Nokia Corporation and/or its subsidiary(-ies)\n" \
47
+ "Copyright (C) 2009 Pierre Ossman for Cendio AB\n" \
48
+ "Copyright (C) 1999-2006 MIYASAKA Masaru\n" \
49
+ "Copyright (C) 1991-2016 Thomas G. Lane, Guido Vollbeding"
50
+
51
+ #define JCOPYRIGHT_SHORT \
52
+ "Copyright (C) 1991-2019 The libjpeg-turbo Project and many others"