# MvpHelper (opens new window) English Document (opens new window)
# 注意! 你正在阅读一篇转载自 GitHub 的文章, 请注意时效性. 该博客并不周期性维护, 一切内容应以 GitHub 仓库 (opens new window) 为准.
一款适用于 Intellij IDEA 和 Android Studio 的插件, 可用于为MVP架构生成接口以及实现类, 解放双手.
分支自 https://github.com/githubwing/MVPHelper, 并基于个人需求重写实现方式
欢迎 Issue Report, 欢迎 Feature Request, 欢迎 Pull Request.
# 预览
Contract模式:

Presenter模式 (已设置后缀Impl):

后缀支持:

错误提示:


# 注意
对于 MVP 模式, 定义一个 Contract 类来放置 Model, View, Presenter 的接口, 将大大减少类文件的数量.
例如:
public interface GoodsInfoContract {
interface View {}
interface Presenter {}
interface Model {}
}
# 如何安装
# 方式一: 通过 IDEA 插件管理器安装

# 方式二: 手动安装
# 第一步
下载 MvpHelper_v2_1_release.jar (opens new window) 或者前往 releases (opens new window) 页面下载其他发行版.
# 第二步
安装插件

# 如何使用
在 Contract 类或者 Presenter 类内部, 点击 Generate 菜单或使用快捷键 Alt + Insert, 选择 Mvp Helper 即可生成对应文件.
# 已知特性
移除快捷键
Meta + 1在非
Java源文件中使用快捷键Alt + Insert时, MvpHelper 菜单将不再出现不再限制根目录包名
不再将
contract包限制在根目录下, 并且支持 sub-package 例如:com.example.project.package1.contract.package2.AContract将会生成com.example.project.package1.model.package2.AModel以及com.example.project.package1.presenter.package2.APresenter当
AContract位于presenter包下时将会出现错误提示而非继续生成错误的类支持
File Header Template已实现
Contract模式Contract所处的位置中必须有至少一个包以contract结尾- 强制
Contract为interface类型 Contract中的三个接口不包含多余的修饰符- 重复生成将删除旧文件并重新生成
已实现
Presenter模式Presenter所处的位置中必须有至少一个包以presenter结尾- 在
Presenter中启动插件将复刻Contract模式下的实现方式 Presenter模式在自定义后缀的情况下不会删除原有Presenter, 因此我们建议使用Contract模式
# TODO
- 实现
Activity模式 - 实现
Fragment模式 - 将生成的文件自动添加到 Git (考虑到要进一步学习Git的命令行语法等相关内容, 可能会鸽)
# 参考资源
- Intellij Platform SDK DevGuide (opens new window)
- Persisting State of Components (opens new window) How to save and load plugin configs
- Customizing the IDEA Settings Dialog (opens new window)
- IDEA Online Source Code (opens new window)
- ApplicationConfigurable, ProjectConfigurable (opens new window)
- PersistStateComponent (opens new window)
- Java Api Sample (opens new window)
- Moxun's bolg (opens new window) (中文博客)
- AndroidStudio/IDEA插件开发学习 (opens new window) (中文博客)
# 更新日志
# v2.x版 - 基于Intellij Open Api 实现 by DevDengChao (opens new window)
- 2017-04-25
- 实现配置信息的存取
- 实现运行时加载配置信息
- 发布 MvpHelper_v2_0_release.jar
- 追加 用户指导.gif
- 向 原仓库 (opens new window) 请求合并
- 在
Android Studio环境下测试Java项目与Android项目 - 修复Merge后造成的
Contract修饰符异常,强制生成后的Contract为public interface PrefixContract - 修复配置面板在销毁时触发的
AbstractMethodException - 发布 MvpHelper_v2_1_release.jar
- 2017-04-24
- 实现配置面板布局
- 实现
Presenter模式下的包生成类PresenterModeDirGenerator - 抽取各功能实现类接口,重新分包
- 基于
Intellij Open Api更新Contract而非以替换文本的方式更新- 强制
Contract为interface - 移除
Contract中接口的多余修饰符public
- 强制
- 2017-04-23
- 实现在指定包下生成类文件, 并注入包信息
- 实现让生成类实现特定接口
- 更新
README.CN.MD
- 2017-04-15 更新对当前环境的判定规则
- 2017-04-12 实现
Action的可见性判定, 当用户尝试通过Alt + Insert启动插件时, 将判断当前环境是否为Java源文件环境, 当条件不成立时将不再显示插件动作 - 2017-04-11 实现
DirGenerator与FileGenerator用于分别生成package与class - 2017-04-10 实现
EnvironmentChecker用于检查当前环境是否满足生成条件:- Java源文件的文件名是否以
Contract结尾, 并处于contract包下 - Java源文件的文件名是否以
Presenter结尾, 并处于presenter包下
- Java源文件的文件名是否以
# v1.1版 - 基于Java IO Api 实现 by githubwing (opens new window)
- 2017-04-10 将源文件分包并尝试重构
- 2017-04-09 移除源文件中的
C语言异味 - 2017-04-06 分支自 原仓库 (opens new window), 并向源文件中追加注释, 以便阅读
# For Eclipse

# License
Copyright 2016 androidwing1992
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.