sterepando commited on
Commit
73a7679
·
verified ·
1 Parent(s): 5089add

Update Dockerfile

Browse files
Files changed (1) hide show
  1. Dockerfile +16 -25
Dockerfile CHANGED
@@ -13,7 +13,7 @@ RUN apt-get update && \
13
  RUN pip install --no-cache-dir gradio
14
 
15
  # -----------------------------------------------------------------------------
16
- # Android SDK
17
  # -----------------------------------------------------------------------------
18
  ENV ANDROID_SDK_ROOT=/opt/android-sdk
19
  ENV CMDLINE_TOOLS_URL=https://dl.google.com/android/repository/commandlinetools-linux-11076708_latest.zip
@@ -26,8 +26,9 @@ RUN mkdir -p ${ANDROID_SDK_ROOT}/cmdline-tools && \
26
 
27
  ENV PATH=${ANDROID_SDK_ROOT}/cmdline-tools/latest/bin:${PATH}
28
 
 
29
  RUN yes | sdkmanager --licenses >/dev/null && \
30
- sdkmanager "build-tools;34.0.0" "platforms;android-34"
31
 
32
  # -----------------------------------------------------------------------------
33
  # Сборка
@@ -53,46 +54,36 @@ RUN mkdir -p luajava/src/main/java/party/iroiro/luajava/util && \
53
  echo ' public static void register(Class<?> c, boolean b) {}' >> luajava/src/main/java/party/iroiro/luajava/util/GlobalLibraryLoader.java && \
54
  echo '}' >> luajava/src/main/java/party/iroiro/luajava/util/GlobalLibraryLoader.java
55
 
56
- # 4. FIX: Рефакторинг LuaException/LuaError (Обход бага d8)
57
- # Удаляем старый файл ЖЕСТКО через find
58
- RUN find . -name "LuaException.java" -delete
59
-
60
- # Создаем LuaError.java (Enum)
61
  RUN echo 'package party.iroiro.luajava;' > luajava/src/main/java/party/iroiro/luajava/LuaError.java && \
62
  echo 'public enum LuaError { OK, YIELD, RUNTIME, SYNTAX, MEMORY, GC, ERR, FILE, HANDLER, JAVA; ' >> luajava/src/main/java/party/iroiro/luajava/LuaError.java && \
63
  echo 'public int code() { return ordinal(); } }' >> luajava/src/main/java/party/iroiro/luajava/LuaError.java
64
-
65
- # Создаем LuaException.java (Класс, ссылающийся на Enum)
66
  RUN echo 'package party.iroiro.luajava;' > luajava/src/main/java/party/iroiro/luajava/LuaException.java && \
67
  echo 'public class LuaException extends RuntimeException {' >> luajava/src/main/java/party/iroiro/luajava/LuaException.java && \
68
  echo ' public LuaException(String msg) { super(msg); }' >> luajava/src/main/java/party/iroiro/luajava/LuaException.java && \
69
  echo ' public LuaException(Throwable cause) { super(cause); }' >> luajava/src/main/java/party/iroiro/luajava/LuaException.java && \
70
  echo ' public LuaException(LuaError error, String msg) { super(error.toString() + ": " + msg); }' >> luajava/src/main/java/party/iroiro/luajava/LuaException.java && \
71
  echo '}' >> luajava/src/main/java/party/iroiro/luajava/LuaException.java
72
-
73
- # Заменяем все ссылки LuaException.LuaError -> LuaError
74
  RUN find . -name "*.java" -exec sed -i 's/LuaException\.LuaError/LuaError/g' {} +
75
-
76
- # Добавляем импорт LuaError
77
  RUN find . -name "*.java" -exec sed -i '/^package /a import party.iroiro.luajava.LuaError;' {} +
78
 
79
- # 5. Удаляем аннотации и ЧИСТИМ ИМПОРТЫ (удаляем старый импорт вложенного класса)
80
  RUN find . -name "*.java" -exec sed -i 's/@NotNull//g' {} + && \
81
  find . -name "*.java" -exec sed -i 's/@Nullable//g' {} + && \
82
  find . -name "*.java" -exec sed -i '/import org.jetbrains.annotations/d' {} + && \
83
  find . -name "*.java" -exec sed -i '/import party.iroiro.luajava.LuaException.LuaError;/d' {} +
84
 
85
- # 6. Компиляция
86
  RUN mkdir classes
87
- RUN javac -source 8 -target 8 -d classes $(find . -name "*.java")
88
-
89
- # ПРОВЕРКА: Если вдруг javac все-таки создал вложенный класс, удаляем его
90
- RUN find classes -name "*LuaException\$LuaError.class" -delete
91
-
92
- # 7. Сборка DEX
93
- RUN ${ANDROID_SDK_ROOT}/build-tools/34.0.0/d8 \
94
- --lib ${ANDROID_SDK_ROOT}/platforms/android-34/android.jar \
95
- --min-api 26 \
96
  --output . \
97
  $(find classes -name "*.class") && \
98
  mv classes.dex /app/luajava_wrapper.dex
@@ -109,7 +100,7 @@ RUN echo 'import gradio as gr' > app.py && \
109
  echo '' >> app.py && \
110
  echo 'with gr.Blocks() as demo:' >> app.py && \
111
  echo ' gr.Markdown("# Download LuaJava DEX")' >> app.py && \
112
- echo ' gr.Markdown("Compilation SUCCESS! No inner classes.")' >> app.py && \
113
  echo ' gr.File(value=file_path, label="luajava_wrapper.dex", interactive=False)' >> app.py && \
114
  echo '' >> app.py && \
115
  echo 'demo.launch(server_name="0.0.0.0", server_port=7860)' >> app.py
 
13
  RUN pip install --no-cache-dir gradio
14
 
15
  # -----------------------------------------------------------------------------
16
+ # Android SDK (Build Tools 30.0.3 - Последний оплот стабильности)
17
  # -----------------------------------------------------------------------------
18
  ENV ANDROID_SDK_ROOT=/opt/android-sdk
19
  ENV CMDLINE_TOOLS_URL=https://dl.google.com/android/repository/commandlinetools-linux-11076708_latest.zip
 
26
 
27
  ENV PATH=${ANDROID_SDK_ROOT}/cmdline-tools/latest/bin:${PATH}
28
 
29
+ # Ставим 30.0.3
30
  RUN yes | sdkmanager --licenses >/dev/null && \
31
+ sdkmanager "build-tools;30.0.3" "platforms;android-30"
32
 
33
  # -----------------------------------------------------------------------------
34
  # Сборка
 
54
  echo ' public static void register(Class<?> c, boolean b) {}' >> luajava/src/main/java/party/iroiro/luajava/util/GlobalLibraryLoader.java && \
55
  echo '}' >> luajava/src/main/java/party/iroiro/luajava/util/GlobalLibraryLoader.java
56
 
57
+ # 4. FIX: Рефакторинг LuaException/LuaError
58
+ RUN rm luajava/src/main/java/party/iroiro/luajava/LuaException.java
 
 
 
59
  RUN echo 'package party.iroiro.luajava;' > luajava/src/main/java/party/iroiro/luajava/LuaError.java && \
60
  echo 'public enum LuaError { OK, YIELD, RUNTIME, SYNTAX, MEMORY, GC, ERR, FILE, HANDLER, JAVA; ' >> luajava/src/main/java/party/iroiro/luajava/LuaError.java && \
61
  echo 'public int code() { return ordinal(); } }' >> luajava/src/main/java/party/iroiro/luajava/LuaError.java
 
 
62
  RUN echo 'package party.iroiro.luajava;' > luajava/src/main/java/party/iroiro/luajava/LuaException.java && \
63
  echo 'public class LuaException extends RuntimeException {' >> luajava/src/main/java/party/iroiro/luajava/LuaException.java && \
64
  echo ' public LuaException(String msg) { super(msg); }' >> luajava/src/main/java/party/iroiro/luajava/LuaException.java && \
65
  echo ' public LuaException(Throwable cause) { super(cause); }' >> luajava/src/main/java/party/iroiro/luajava/LuaException.java && \
66
  echo ' public LuaException(LuaError error, String msg) { super(error.toString() + ": " + msg); }' >> luajava/src/main/java/party/iroiro/luajava/LuaException.java && \
67
  echo '}' >> luajava/src/main/java/party/iroiro/luajava/LuaException.java
 
 
68
  RUN find . -name "*.java" -exec sed -i 's/LuaException\.LuaError/LuaError/g' {} +
 
 
69
  RUN find . -name "*.java" -exec sed -i '/^package /a import party.iroiro.luajava.LuaError;' {} +
70
 
71
+ # 5. Удаляем аннотации
72
  RUN find . -name "*.java" -exec sed -i 's/@NotNull//g' {} + && \
73
  find . -name "*.java" -exec sed -i 's/@Nullable//g' {} + && \
74
  find . -name "*.java" -exec sed -i '/import org.jetbrains.annotations/d' {} + && \
75
  find . -name "*.java" -exec sed -i '/import party.iroiro.luajava.LuaException.LuaError;/d' {} +
76
 
77
+ # 6. Компиляция (-g:none для удаления отладочной инфы, которая крашит d8)
78
  RUN mkdir classes
79
+ RUN javac -g:none -source 8 -target 8 -d classes $(find . -name "*.java")
80
+
81
+ # 7. Сборка DEX (Build Tools 30.0.3 + --debug чтобы отключить оптимизации d8)
82
+ # Иногда --debug помогает обойти баги оптимизатора
83
+ RUN ${ANDROID_SDK_ROOT}/build-tools/30.0.3/d8 \
84
+ --lib ${ANDROID_SDK_ROOT}/platforms/android-30/android.jar \
85
+ --min-api 21 \
86
+ --debug \
 
87
  --output . \
88
  $(find classes -name "*.class") && \
89
  mv classes.dex /app/luajava_wrapper.dex
 
100
  echo '' >> app.py && \
101
  echo 'with gr.Blocks() as demo:' >> app.py && \
102
  echo ' gr.Markdown("# Download LuaJava DEX")' >> app.py && \
103
+ echo ' gr.Markdown("Compilation SUCCESS! (Using BT 30.0.3 + NoDebugInfo)")' >> app.py && \
104
  echo ' gr.File(value=file_path, label="luajava_wrapper.dex", interactive=False)' >> app.py && \
105
  echo '' >> app.py && \
106
  echo 'demo.launch(server_name="0.0.0.0", server_port=7860)' >> app.py