You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
121 lines
2.8 KiB
121 lines
2.8 KiB
/*
|
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
*
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
*/
|
|
import java.util.ArrayList;
|
|
import java.util.LinkedList;
|
|
import java.util.Set;
|
|
|
|
class HoistGlobal {
|
|
|
|
public static int svar = 0;
|
|
|
|
int read_global() {
|
|
return svar;
|
|
}
|
|
|
|
int return_one() {
|
|
return 1;
|
|
}
|
|
|
|
class Foo {
|
|
void set() {
|
|
svar = 5;
|
|
}
|
|
|
|
int read_global() {
|
|
return svar;
|
|
}
|
|
|
|
int return_zero() {
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
int global_modification_dont_hoist_FP(int size) {
|
|
Foo f = new Foo();
|
|
int d = 0;
|
|
for (int i = 0; i < size; i++) {
|
|
d += read_global(); // don't hoist since set() changes a global var in the loop
|
|
f.set();
|
|
f.read_global(); // don't hoist
|
|
}
|
|
return d;
|
|
}
|
|
|
|
int global_modification_hoist(ArrayList<?> list) {
|
|
Foo f = new Foo();
|
|
int d = 0;
|
|
for (int i = 0; i < list.size(); i++) {
|
|
d += return_one(); // ok to hoist
|
|
f.set(); // don't invalidate size()
|
|
f.return_zero(); // ok to hoist since doesn't read global
|
|
}
|
|
return d;
|
|
}
|
|
|
|
void call_global_modification_dont_hoist(int size) {
|
|
for (int i = 0; i < size; i++) {
|
|
global_modification_dont_hoist_FP(size);
|
|
}
|
|
}
|
|
|
|
private void processModulesDirectory_dont_hoist_FP(
|
|
Set<String> modulesToDelete, String[] existingFiles) {
|
|
final AppModuleFileInfo fInfo = new AppModuleFileInfo();
|
|
for (String existingFile : existingFiles) {
|
|
fInfo.setFileName(existingFile);
|
|
final boolean delete = modulesToDelete.contains(fInfo.mModuleName);
|
|
}
|
|
}
|
|
|
|
private void processModulesDirectory_param_dont_hoist_FP(
|
|
Set<String> modulesToDelete,
|
|
String[] existingFiles,
|
|
AppModuleFileInfo fInfo,
|
|
AppModuleFileInfo fInfo2) {
|
|
for (String existingFile : existingFiles) {
|
|
fInfo.setFileName(existingFile);
|
|
|
|
final boolean delete = modulesToDelete.contains(fInfo2.mModuleName);
|
|
}
|
|
}
|
|
|
|
private void processModulesDirectory_hoist(Set<Integer> modulesToDelete, String[] existingFiles) {
|
|
final AppModuleFileInfo fInfo = new AppModuleFileInfo();
|
|
for (String existingFile : existingFiles) {
|
|
fInfo.setFileName(existingFile);
|
|
final boolean delete = modulesToDelete.contains(fInfo.x);
|
|
}
|
|
}
|
|
|
|
void remove_first_dont_hoist(LinkedList<String> list) {
|
|
|
|
while (list.size() >= 10) {
|
|
list.removeFirst();
|
|
}
|
|
}
|
|
|
|
String get_first_hoist_FN(LinkedList<String> list, String s) {
|
|
for (int i = 0; i <= 10; i++) {
|
|
String first = list.getFirst(); // list is invalidated
|
|
if (list.contains(s)) { // hoist
|
|
return first;
|
|
}
|
|
}
|
|
return "";
|
|
}
|
|
}
|
|
|
|
class AppModuleFileInfo {
|
|
|
|
static String mModuleName;
|
|
static Integer x;
|
|
|
|
void setFileName(String fileName) {
|
|
mModuleName = fileName;
|
|
}
|
|
}
|