Browse Source
* commit 'baacba086ca8f2532b4f31f15b7cfdf8899098dc': MOBILE-19684 同时安装顶部参数插件和导航参数插件时设计器显示重复值 REPORT-14515 环境切换后模板另存面板没有刷新 REPORT-13202 包含插件控件的模板切换环境后存储出错 REPORT-14020 可以重复打开设计器 调试的代码上次误传了 记录次数bugfix REPORT-14022 【难还原】最新的29号release,莫名其妙的卡住很久,后台百分百的cpu占用 合并发送,去重;每次query 200条,放入内存,发送成功再进行新的请求 同步更改到finalpersist/10.0
Kara
6 years ago
9 changed files with 330 additions and 80 deletions
@ -0,0 +1,63 @@ |
|||||||
|
package com.fr.design.mainframe; |
||||||
|
|
||||||
|
import com.fr.file.FILE; |
||||||
|
import com.fr.stable.CoreConstants; |
||||||
|
import com.fr.third.javax.annotation.Nonnull; |
||||||
|
import com.fr.third.javax.annotation.Nullable; |
||||||
|
|
||||||
|
import java.util.ArrayList; |
||||||
|
import java.util.List; |
||||||
|
|
||||||
|
public final class JTemplateFactory { |
||||||
|
private static final List<App<?>> ALL_APP = new ArrayList<App<?>>(); |
||||||
|
|
||||||
|
private JTemplateFactory() { |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* 生成设计器编辑模板对象 |
||||||
|
* |
||||||
|
* @param file 包含了模板名称,类型以及内容的文件 |
||||||
|
* @return 设计器编辑的模板对象 |
||||||
|
*/ |
||||||
|
@Nullable |
||||||
|
public static JTemplate<?, ?> createJTemplate(@Nonnull FILE file) { |
||||||
|
|
||||||
|
String fileName = file.getName(); |
||||||
|
int indexOfLastDot = fileName.lastIndexOf(CoreConstants.DOT); |
||||||
|
if (indexOfLastDot < 0) { |
||||||
|
return null; |
||||||
|
} |
||||||
|
String fileExtension = fileName.substring(indexOfLastDot + 1); |
||||||
|
for (App<?> app : ALL_APP) { |
||||||
|
String[] defaultAppExtensions = app.defaultExtensions(); |
||||||
|
for (String defaultAppExtension : defaultAppExtensions) { |
||||||
|
if (defaultAppExtension.equalsIgnoreCase(fileExtension)) { |
||||||
|
JTemplate<?, ?> jt = app.openTemplate(file); |
||||||
|
if (jt != null) { |
||||||
|
return jt; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
return null; |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
/** |
||||||
|
* 注册app. |
||||||
|
* |
||||||
|
* @param app 注册app. |
||||||
|
*/ |
||||||
|
public static void register(App<?> app) { |
||||||
|
if (app != null) { |
||||||
|
ALL_APP.add(app); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
public static void remove(App<?> app) { |
||||||
|
if (app != null) { |
||||||
|
ALL_APP.remove(app); |
||||||
|
} |
||||||
|
} |
||||||
|
} |
@ -0,0 +1,106 @@ |
|||||||
|
package com.fr.file; |
||||||
|
|
||||||
|
import javax.swing.Icon; |
||||||
|
import javax.transaction.NotSupportedException; |
||||||
|
import java.io.ByteArrayInputStream; |
||||||
|
import java.io.InputStream; |
||||||
|
import java.io.OutputStream; |
||||||
|
|
||||||
|
/** |
||||||
|
* 切换环境用于暂存的文件类型 |
||||||
|
*/ |
||||||
|
public class StashedFILE implements FILE { |
||||||
|
|
||||||
|
private FILE file; |
||||||
|
private byte[] content; |
||||||
|
|
||||||
|
public StashedFILE(FILE file, byte[] content) { |
||||||
|
this.file = file; |
||||||
|
this.content = content; |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
public String prefix() { |
||||||
|
return file.prefix(); |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
public boolean isDirectory() { |
||||||
|
return file.isDirectory(); |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
public String getName() { |
||||||
|
return file.getName(); |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
public Icon getIcon() { |
||||||
|
return file.getIcon(); |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
public String getPath() { |
||||||
|
return file.getPath(); |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
public void setPath(String path) { |
||||||
|
throw new UnsupportedOperationException(); |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
public FILE getParent() { |
||||||
|
throw new UnsupportedOperationException(); |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
public FILE[] listFiles() { |
||||||
|
throw new UnsupportedOperationException(); |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
public boolean createFolder(String name) { |
||||||
|
throw new UnsupportedOperationException(); |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
public boolean mkfile() throws Exception { |
||||||
|
throw new UnsupportedOperationException(); |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
public boolean exists() { |
||||||
|
return false; |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
public void closeTemplate() throws Exception { |
||||||
|
// do nothing
|
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
public InputStream asInputStream() throws Exception { |
||||||
|
return new ByteArrayInputStream(content); |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
public OutputStream asOutputStream() throws Exception { |
||||||
|
throw new NotSupportedException(); |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
public String getEnvFullName() { |
||||||
|
return file.getEnvFullName(); |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
public boolean isMemFile() { |
||||||
|
return true; |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
public boolean isEnvFile() { |
||||||
|
return false; |
||||||
|
} |
||||||
|
} |
Loading…
Reference in new issue