File: BytecodeGeneratorFactory.java

package info (click to toggle)
openjdk-11 11.0.16%2B8-1~deb10u1
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 784,576 kB
  • sloc: java: 5,128,021; xml: 1,192,224; cpp: 1,124,021; ansic: 422,433; javascript: 155,577; sh: 17,084; objc: 13,327; python: 4,522; asm: 3,570; makefile: 2,858; awk: 351; sed: 172; perl: 114; jsp: 24; csh: 3
file content (56 lines) | stat: -rw-r--r-- 2,309 bytes parent folder | download | duplicates (11)
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
50
51
52
53
54
55
56
/*
 * Copyright (c) 2014, 2018, Oracle and/or its affiliates. All rights reserved.
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
 *
 * This code is free software; you can redistribute it and/or modify it
 * under the terms of the GNU General Public License version 2 only, as
 * published by the Free Software Foundation.
 *
 * This code is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
 * version 2 for more details (a copy is included in the LICENSE file that
 * accompanied this code).
 *
 * You should have received a copy of the GNU General Public License version
 * 2 along with this work; if not, write to the Free Software Foundation,
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
 *
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
 * or visit www.oracle.com if you need additional information or have any
 * questions.
 */
package gc.g1.unloading.bytecode;

import java.util.HashMap;
import java.util.Map;
import java.util.Random;

import vm.share.InMemoryJavaCompiler;

/**
 * BytecodeFactory that employs in memory compilation.
 */
public class BytecodeGeneratorFactory implements BytecodeFactory {

    private Random random;

    private SourceGenerator sourceGenerator;

    public BytecodeGeneratorFactory(long seed) {
        random = new Random(seed);
        sourceGenerator = new SourceGenerator(random.nextLong());
    }

    @Override
    public Bytecode createBytecode(String className) {
        Map<String, CharSequence> sources = new HashMap<String, CharSequence>();
        sources.put(className, sourceGenerator.generateSource(className,
                "public static void main() { System.out.println(\"From main method in in-mem-compiled code " + random.nextGaussian() +
                        " + str_bytesToReplace0 str_bytesToReplace1\"); }\n " +
                        "public static int methodForCompilation(Object object) { int i = object.hashCode(); i = i * 2000 / 1994 + 153; return i; }\n"));
        byte[] bytecode = InMemoryJavaCompiler.compile(sources).values().iterator().next();
        return new Bytecode(className, bytecode);
    }

}