diff --git a/app-release-1.17.0221.apk b/app-release-1.17.0223.apk
similarity index 64%
rename from app-release-1.17.0221.apk
rename to app-release-1.17.0223.apk
index 86415098..26658ee9 100644
Binary files a/app-release-1.17.0221.apk and b/app-release-1.17.0223.apk differ
diff --git a/app/build.gradle b/app/build.gradle
index bc642454..f373cf13 100644
--- a/app/build.gradle
+++ b/app/build.gradle
@@ -7,8 +7,8 @@ android {
applicationId "com.stardust.scriptdroid"
minSdkVersion 19
targetSdkVersion 23
- versionCode 31
- versionName "1.17.0221"
+ versionCode 34
+ versionName "1.17.0223"
testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
}
buildTypes {
diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml
index 81c7df88..99a39b44 100644
--- a/app/src/main/AndroidManifest.xml
+++ b/app/src/main/AndroidManifest.xml
@@ -90,9 +90,9 @@
+ android:label="编辑脚本">
@@ -129,7 +129,47 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/app/src/main/assets/javasccript_engine_init.js b/app/src/main/assets/javasccript_engine_init.js
index 4568cc7a..f579d7c3 100644
--- a/app/src/main/assets/javasccript_engine_init.js
+++ b/app/src/main/assets/javasccript_engine_init.js
@@ -132,4 +132,8 @@ var getPackageName = function(){
var getActivityName = function(){
return droid.getActivityName();
+}
+
+var setClip = function(text){
+ droid.setClip(text);
}
\ No newline at end of file
diff --git a/app/src/main/java/com/stardust/scriptdroid/droid/runtime/DroidRuntime.java b/app/src/main/java/com/stardust/scriptdroid/droid/runtime/DroidRuntime.java
index 8dc28667..88009d0f 100644
--- a/app/src/main/java/com/stardust/scriptdroid/droid/runtime/DroidRuntime.java
+++ b/app/src/main/java/com/stardust/scriptdroid/droid/runtime/DroidRuntime.java
@@ -1,5 +1,8 @@
package com.stardust.scriptdroid.droid.runtime;
+import android.content.ClipData;
+import android.content.ClipboardManager;
+import android.content.Context;
import android.content.Intent;
import android.content.pm.ApplicationInfo;
import android.content.pm.PackageManager;
@@ -145,6 +148,15 @@ public class DroidRuntime implements IDroidRuntime {
return performAction(target.createAction(AccessibilityNodeInfo.ACTION_SET_TEXT, text));
}
+ public void setClip(final String text) {
+ mUIHandler.post(new Runnable() {
+ @Override
+ public void run() {
+ ((ClipboardManager) App.getApp().getSystemService(Context.CLIPBOARD_SERVICE)).setPrimaryClip(ClipData.newPlainText(TAG, text));
+ }
+ });
+ }
+
@Override
public boolean paste(ActionTarget target) {
return performAction(target.createAction(AccessibilityNodeInfo.ACTION_PASTE));
diff --git a/app/src/main/java/com/stardust/scriptdroid/droid/runtime/action/ActionPerformAccessibilityDelegate.java b/app/src/main/java/com/stardust/scriptdroid/droid/runtime/action/ActionPerformAccessibilityDelegate.java
index cde13bba..344197e2 100644
--- a/app/src/main/java/com/stardust/scriptdroid/droid/runtime/action/ActionPerformAccessibilityDelegate.java
+++ b/app/src/main/java/com/stardust/scriptdroid/droid/runtime/action/ActionPerformAccessibilityDelegate.java
@@ -73,12 +73,14 @@ public class ActionPerformAccessibilityDelegate implements AccessibilityDelegate
if (latestPackage == null)
return;
ActionPerformAccessibilityDelegate.latestPackage = latestPackage.toString();
- ComponentName componentName = new ComponentName(latestPackage.toString(), latestClass == null ? null : latestClass.toString());
+ if(latestClass == null)
+ return;
try {
+ ComponentName componentName = new ComponentName(latestPackage.toString(), latestClass.toString());
ActivityInfo activityInfo = App.getApp().getPackageManager().getActivityInfo(componentName, 0);
ActionPerformAccessibilityDelegate.latestActivity = activityInfo.name;
- } catch (PackageManager.NameNotFoundException ignored) {
-
+ } catch (PackageManager.NameNotFoundException e) {
+ e.printStackTrace();
}
}
diff --git a/app/src/main/java/com/stardust/scriptdroid/ui/edit/EditAndRunIntentActivity.java b/app/src/main/java/com/stardust/scriptdroid/external/open/EditIntentActivity.java
similarity index 83%
rename from app/src/main/java/com/stardust/scriptdroid/ui/edit/EditAndRunIntentActivity.java
rename to app/src/main/java/com/stardust/scriptdroid/external/open/EditIntentActivity.java
index 9c786e44..84f874a7 100644
--- a/app/src/main/java/com/stardust/scriptdroid/ui/edit/EditAndRunIntentActivity.java
+++ b/app/src/main/java/com/stardust/scriptdroid/external/open/EditIntentActivity.java
@@ -1,4 +1,4 @@
-package com.stardust.scriptdroid.ui.edit;
+package com.stardust.scriptdroid.external.open;
import android.content.Intent;
import android.os.Bundle;
@@ -8,12 +8,13 @@ import android.widget.Toast;
import com.stardust.scriptdroid.ui.BaseActivity;
import com.stardust.scriptdroid.R;
+import com.stardust.scriptdroid.ui.edit.EditActivity;
/**
* Created by Stardust on 2017/2/2.
*/
-public class EditAndRunIntentActivity extends BaseActivity {
+public class EditIntentActivity extends BaseActivity {
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
@@ -24,6 +25,7 @@ public class EditAndRunIntentActivity extends BaseActivity {
e.printStackTrace();
Toast.makeText(this, R.string.edit_and_run_handle_intent_error, Toast.LENGTH_LONG).show();
}
+ finish();
}
private void handleIntent() {
diff --git a/app/src/main/java/com/stardust/scriptdroid/ui/edit/ImportIntentActivity.java b/app/src/main/java/com/stardust/scriptdroid/external/open/ImportIntentActivity.java
similarity index 84%
rename from app/src/main/java/com/stardust/scriptdroid/ui/edit/ImportIntentActivity.java
rename to app/src/main/java/com/stardust/scriptdroid/external/open/ImportIntentActivity.java
index e9efc9de..0176cace 100644
--- a/app/src/main/java/com/stardust/scriptdroid/ui/edit/ImportIntentActivity.java
+++ b/app/src/main/java/com/stardust/scriptdroid/external/open/ImportIntentActivity.java
@@ -1,10 +1,11 @@
-package com.stardust.scriptdroid.ui.edit;
+package com.stardust.scriptdroid.external.open;
import android.content.Intent;
import android.os.Bundle;
import android.support.annotation.NonNull;
import android.support.annotation.Nullable;
import android.text.TextUtils;
+import android.widget.Toast;
import com.afollestad.materialdialogs.MaterialDialog;
import com.stardust.scriptdroid.ui.BaseActivity;
@@ -24,7 +25,13 @@ public class ImportIntentActivity extends BaseActivity {
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
- handleIntent();
+ try {
+ handleIntent();
+ } catch (Exception e) {
+ e.printStackTrace();
+ Toast.makeText(this, R.string.edit_and_run_handle_intent_error, Toast.LENGTH_LONG).show();
+ }
+ finish();
}
private void handleIntent() {
diff --git a/app/src/main/java/com/stardust/scriptdroid/external/open/RunIntentActivity.java b/app/src/main/java/com/stardust/scriptdroid/external/open/RunIntentActivity.java
new file mode 100644
index 00000000..62e6ec0a
--- /dev/null
+++ b/app/src/main/java/com/stardust/scriptdroid/external/open/RunIntentActivity.java
@@ -0,0 +1,40 @@
+package com.stardust.scriptdroid.external.open;
+
+import android.app.Activity;
+import android.content.Intent;
+import android.os.Bundle;
+import android.support.annotation.Nullable;
+import android.text.TextUtils;
+import android.widget.Toast;
+
+import com.stardust.scriptdroid.R;
+import com.stardust.scriptdroid.external.shortcut.ShortcutActivity;
+
+/**
+ * Created by Stardust on 2017/2/22.
+ */
+
+public class RunIntentActivity extends Activity {
+
+ @Override
+ protected void onCreate(@Nullable Bundle savedInstanceState) {
+ super.onCreate(savedInstanceState);
+ try {
+ handleIntent();
+ } catch (Exception e) {
+ e.printStackTrace();
+ Toast.makeText(this, R.string.edit_and_run_handle_intent_error, Toast.LENGTH_LONG).show();
+ }
+ finish();
+ }
+
+ private void handleIntent() {
+ Intent intent = getIntent();
+ String path = intent.getData().getPath();
+ if (!TextUtils.isEmpty(path)) {
+ startActivity(new Intent(this, ShortcutActivity.class)
+ .addFlags(Intent.FLAG_ACTIVITY_NEW_TASK)
+ .putExtra("path", path));
+ }
+ }
+}
diff --git a/app/src/main/java/com/stardust/scriptdroid/file/FileUtils.java b/app/src/main/java/com/stardust/scriptdroid/file/FileUtils.java
index a6aea5e2..706bec3a 100644
--- a/app/src/main/java/com/stardust/scriptdroid/file/FileUtils.java
+++ b/app/src/main/java/com/stardust/scriptdroid/file/FileUtils.java
@@ -198,4 +198,17 @@ public class FileUtils {
return false;
}
}
+
+ public static String generateNotExistingPath(String path, String extension) {
+ if (!new File(path + extension).exists())
+ return path + extension;
+ int i = 0;
+ while (true) {
+ String pathI = path + "(" + i + ")" + extension;
+ if (!new File(pathI).exists())
+ return pathI;
+ i++;
+ }
+
+ }
}
\ No newline at end of file
diff --git a/app/src/main/java/com/stardust/scriptdroid/ui/edit/completion/CodeCompletion.java b/app/src/main/java/com/stardust/scriptdroid/ui/edit/completion/CodeCompletion.java
index 219ca13c..33bdcdc1 100644
--- a/app/src/main/java/com/stardust/scriptdroid/ui/edit/completion/CodeCompletion.java
+++ b/app/src/main/java/com/stardust/scriptdroid/ui/edit/completion/CodeCompletion.java
@@ -47,7 +47,7 @@ public class CodeCompletion implements TextWatcher {
}
interface OnCodeCompletionChangeListener {
- void OnCodeCompletionChange(Collection list);
+ void OnCodeCompletionChange(Collection... list);
}
private static final String TAG = "CodeCompletion";
@@ -101,14 +101,14 @@ public class CodeCompletion implements TextWatcher {
private static final String[] KEYWORDS = {"arguments", "break", "case", "catch", "class", "continue", "default", "do", "else", "eval", "export", "false", "for", "function", "if", "import", "in", "int", "new", "null", "package", "return", "switch", "this", "throw", "throws", "true", "try", "typeof", "var", "volatile", "while", "with", "Array", "Date", "hasOwnProperty", "Infinity", "isFinite", "isNaN", "isPrototypeOf", "length", "Math", "NaN", "name", "Number", "Object", "prototype", "String", "toString", "undefined", "valueOf"};
private static final int KEY_WORD_LENGTH_MAX = 15;
- private static final String[] FUNCTIONS = {"toast", "launchPackage", "launch", "launchApp", "click", "longClick", "scrollUp", "scrollDown", "select", "focus", "paste", "input", "sleep", "isStopped", "notStopped", "log", "err", "openConsole", "clearConsole", "shell", "getTexts", "getPackageName", "getActivityName"};
+ private static final String[] FUNCTIONS = {"toast", "launchPackage", "launch", "launchApp", "click", "longClick", "scrollUp", "scrollDown", "select", "focus", "paste", "input", "sleep", "isStopped", "notStopped", "log", "err", "openConsole", "clearConsole", "shell", "getTexts", "getPackageName", "getActivityName", "setClip"};
private boolean searchCodeCompletion(String str) {
Collection c = searchWordCompletion(str);
c.addAll(searchCodeCompletion(str, FUNCTIONS));
c.addAll(searchKeyWordCompletion(str));
if (c.size() > 0) {
- mOnCodeCompletionChangeListener.OnCodeCompletionChange(c);
+ mOnCodeCompletionChangeListener.OnCodeCompletionChange(c, DEFAULT_CODE_COMPLETION_LIST);
return true;
} else {
mOnCodeCompletionChangeListener.OnCodeCompletionChange(DEFAULT_CODE_COMPLETION_LIST);
diff --git a/app/src/main/java/com/stardust/scriptdroid/ui/edit/completion/InputMethodEnhanceBar.java b/app/src/main/java/com/stardust/scriptdroid/ui/edit/completion/InputMethodEnhanceBar.java
index d2e8bd24..0e0f98e6 100644
--- a/app/src/main/java/com/stardust/scriptdroid/ui/edit/completion/InputMethodEnhanceBar.java
+++ b/app/src/main/java/com/stardust/scriptdroid/ui/edit/completion/InputMethodEnhanceBar.java
@@ -68,9 +68,11 @@ public class InputMethodEnhanceBar extends RecyclerView implements CodeCompletio
}
@Override
- public void OnCodeCompletionChange(Collection list) {
+ public void OnCodeCompletionChange(Collection... lists) {
mCodeCompletionList.clear();
- mCodeCompletionList.addAll(list);
+ for (Collection list : lists) {
+ mCodeCompletionList.addAll(list);
+ }
getAdapter().notifyDataSetChanged();
}
diff --git a/app/src/main/java/com/stardust/scriptdroid/ui/error/IssueReportActivity.java b/app/src/main/java/com/stardust/scriptdroid/ui/error/IssueReportActivity.java
index 90353c0a..83128fdd 100644
--- a/app/src/main/java/com/stardust/scriptdroid/ui/error/IssueReportActivity.java
+++ b/app/src/main/java/com/stardust/scriptdroid/ui/error/IssueReportActivity.java
@@ -25,7 +25,6 @@ public class IssueReportActivity extends IssueReporterActivity {
private boolean mCrash = false;
private Method mReportIssue, mValidateInput;
private boolean mReportFailed = false;
- private String token = "d";
@Override
protected void onCreate(Bundle savedInstanceState) {
@@ -129,7 +128,7 @@ public class IssueReportActivity extends IssueReporterActivity {
@Override
protected String getGuestToken() {
//绕过github安全检查
- return decode("NDlkZDU3NjRiYTk3NzVmZDkxOTA3MDQ4YTdmNzQ1ZDY5NjcyNzEyNA==");
+ return decode("MzA5MWJhNWI0NDM2NWYzOGRmNDA4ZWRhM2Y5MTUxN2ZlNDVlZDBhZQ==");
}
public static String decode(String str) {
diff --git a/app/src/main/java/com/stardust/scriptdroid/ui/main/MainActivity.java b/app/src/main/java/com/stardust/scriptdroid/ui/main/MainActivity.java
index 272bdff6..d8bb2566 100644
--- a/app/src/main/java/com/stardust/scriptdroid/ui/main/MainActivity.java
+++ b/app/src/main/java/com/stardust/scriptdroid/ui/main/MainActivity.java
@@ -163,10 +163,11 @@ public class MainActivity extends BaseActivity implements FileChooserDialog.File
.input(getString(R.string.text_please_input_name), "", new MaterialDialog.InputCallback() {
@Override
public void onInput(@NonNull MaterialDialog dialog, CharSequence input) {
- String path = ScriptFile.DEFAULT_FOLDER + input + ".js";
+ String path = FileUtils.generateNotExistingPath(ScriptFile.DEFAULT_FOLDER + input, ".js");
MainActivity.this.createScriptFile(input.toString(), path, script);
}
- }).show();
+ })
+ .show();
}
private void createScriptFile(String name, String path, String script) {
diff --git a/app/src/main/res/raw/document.md b/app/src/main/res/raw/document.md
index 012604de..82fcb14c 100644
--- a/app/src/main/res/raw/document.md
+++ b/app/src/main/res/raw/document.md
@@ -28,6 +28,7 @@
* `getTexts()` 获取屏幕上的文字列表, 返回一个java.util.List。例如:
* `getPackageName` 获取正在运行的应用包名
* `getActivityName` 获取正在运行的Activity名称
+* `setClip(text)` 设置剪贴板文本
```
launchApp("微信");
while(!click("通讯录"));
diff --git a/app/src/main/res/values/strings.xml b/app/src/main/res/values/strings.xml
index 18d404ec..27ff8cbe 100644
--- a/app/src/main/res/values/strings.xml
+++ b/app/src/main/res/values/strings.xml
@@ -124,4 +124,5 @@
编辑
key_max_length_for_code_completion
代码补全最大文件长度
+ 文件已存在
diff --git a/app/src/test/java/com/stardust/scriptdroid/ExampleUnitTest.java b/app/src/test/java/com/stardust/scriptdroid/ExampleUnitTest.java
index 5330dc4b..fddb18fb 100644
--- a/app/src/test/java/com/stardust/scriptdroid/ExampleUnitTest.java
+++ b/app/src/test/java/com/stardust/scriptdroid/ExampleUnitTest.java
@@ -14,26 +14,6 @@ public class ExampleUnitTest {
@Test
public void testSync() throws Exception {
- new Thread(new Runnable() {
- @Override
- public void run() {
- while (true) {
- synchronized (this) {
- i++;
- }
- }
- }
- }).start();
- new Thread(new Runnable() {
- @Override
- public void run() {
- while (true) {
- synchronized (this) {
- System.out.println(i);
- }
- }
- }
- }).start();
}