ModuleHashes_attribute.java revision 3792:d516975e8110
1/*
2 * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4 *
5 * This code is free software; you can redistribute it and/or modify it
6 * under the terms of the GNU General Public License version 2 only, as
7 * published by the Free Software Foundation.  Oracle designates this
8 * particular file as subject to the "Classpath" exception as provided
9 * by Oracle in the LICENSE file that accompanied this code.
10 *
11 * This code is distributed in the hope that it will be useful, but WITHOUT
12 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
13 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
14 * version 2 for more details (a copy is included in the LICENSE file that
15 * accompanied this code).
16 *
17 * You should have received a copy of the GNU General Public License version
18 * 2 along with this work; if not, write to the Free Software Foundation,
19 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
20 *
21 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
22 * or visit www.oracle.com if you need additional information or have any
23 * questions.
24 */
25
26package com.sun.tools.classfile;
27
28import java.io.IOException;
29
30/**
31 * See JVMS, section 4.8.15.
32 *
33 *  <p><b>This is NOT part of any supported API.
34 *  If you write code that depends on this, you do so at your own risk.
35 *  This code and its internal interfaces are subject to change or
36 *  deletion without notice.</b>
37 */
38public class ModuleHashes_attribute extends Attribute {
39    ModuleHashes_attribute(ClassReader cr, int name_index, int length) throws IOException {
40        super(name_index, length);
41        algorithm_index = cr.readUnsignedShort();
42        hashes_table_length = cr.readUnsignedShort();
43        hashes_table = new Entry[hashes_table_length];
44        for (int i = 0; i < hashes_table_length; i++)
45            hashes_table[i] = new Entry(cr);
46    }
47
48    public ModuleHashes_attribute(ConstantPool constant_pool, int algorithm_index, Entry[] hashes_table)
49            throws ConstantPoolException {
50        this(constant_pool.getUTF8Index(Attribute.ModuleHashes), algorithm_index, hashes_table);
51    }
52
53    public ModuleHashes_attribute(int name_index, int algorithm_index, Entry[] hashes_table) {
54        super(name_index, 2 + 2 + length(hashes_table));
55        this.algorithm_index = algorithm_index;
56        this.hashes_table_length = hashes_table.length;
57        this.hashes_table = hashes_table;
58    }
59
60    @Override
61    public <R, D> R accept(Visitor<R, D> visitor, D data) {
62        return visitor.visitModuleHashes(this, data);
63    }
64
65    private static int length(Entry[] hashes_table) {
66        int len = 0;
67        for (Entry e: hashes_table) {
68            len += e.length();
69        }
70        return len;
71    }
72
73    public final int algorithm_index;
74    public final int hashes_table_length;
75    public final Entry[] hashes_table;
76
77    public static class Entry {
78        Entry(ClassReader cr) throws IOException {
79            module_name_index = cr.readUnsignedShort();
80            int hash_length = cr.readUnsignedShort();
81            hash = new byte[hash_length];
82            for (int i=0; i<hash_length; i++) {
83                hash[i] = (byte) cr.readUnsignedByte();
84            }
85        }
86
87        public int length() {
88            return 4 + hash.length;
89        }
90
91        public final int module_name_index;
92        public final byte[] hash;
93    }
94
95}
96