├── gradle.properties ├── .idea ├── icon.png ├── icon_dark.png ├── copyright │ └── profiles_settings.xml ├── encodings.xml ├── vcs.xml ├── kotlinScripting.xml ├── kotlinc.xml ├── compiler.xml ├── modules.xml ├── gradle.xml ├── modules │ ├── emoji.iml │ └── emoji_test.iml ├── runConfigurations │ ├── Emoji_Support_Plugin__buildPlugin_.xml │ └── Emoji_Support_Plugin__runIde_.xml ├── misc.xml ├── jarRepositories.xml └── libraries-with-intellij-classes.xml ├── website └── images │ ├── commit.gif │ └── code_folding.gif ├── gradle └── wrapper │ ├── gradle-wrapper.jar │ └── gradle-wrapper.properties ├── src └── main │ ├── kotlin │ └── com │ │ └── github │ │ └── shiraji │ │ └── emoji │ │ ├── data │ │ ├── EmojiDataManager.kt │ │ ├── EmojiData.kt │ │ └── pattern │ │ │ ├── PsiPlainTextPattern.kt │ │ │ └── MarkdownPattern.kt │ │ ├── contributor │ │ ├── MarkdownEmojiCompletionContributor.kt │ │ ├── PsiPlainTextCompletionContributor.kt │ │ └── EmojiCompletionContributor.kt │ │ ├── folding │ │ ├── MarkdownTextFoldingBuilder.kt │ │ ├── PsiPlainTextFoldingBuilder.kt │ │ └── EmojiFoldingBuilder.kt │ │ ├── action │ │ └── EmojiPreloadingActivity.kt │ │ ├── listener │ │ └── EmojiDynamicPluginListener.kt │ │ ├── ext │ │ └── CompletionParameters.kt │ │ ├── service │ │ └── EmojiReader.kt │ │ └── completion │ │ └── EmojiCompletionProvider.kt │ └── resources │ └── META-INF │ ├── markdown.xml │ ├── pluginIcon.svg │ └── plugin.xml ├── LATEST.txt ├── RELEASING.md ├── local.properties ├── settings.gradle.kts ├── .github ├── FUNDING.yml └── workflows │ └── workflow.yml ├── CHANGELOG.md ├── README.md ├── .gitignore ├── gradlew.bat ├── gradlew └── LICENSE /gradle.properties: -------------------------------------------------------------------------------- 1 | kotlinVersion=1.3.71 -------------------------------------------------------------------------------- /.idea/icon.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/shiraji/emoji/HEAD/.idea/icon.png -------------------------------------------------------------------------------- /.idea/icon_dark.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/shiraji/emoji/HEAD/.idea/icon_dark.png -------------------------------------------------------------------------------- /website/images/commit.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/shiraji/emoji/HEAD/website/images/commit.gif -------------------------------------------------------------------------------- /website/images/code_folding.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/shiraji/emoji/HEAD/website/images/code_folding.gif -------------------------------------------------------------------------------- /gradle/wrapper/gradle-wrapper.jar: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/shiraji/emoji/HEAD/gradle/wrapper/gradle-wrapper.jar -------------------------------------------------------------------------------- /.idea/copyright/profiles_settings.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | -------------------------------------------------------------------------------- /.idea/encodings.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | -------------------------------------------------------------------------------- /src/main/kotlin/com/github/shiraji/emoji/data/EmojiDataManager.kt: -------------------------------------------------------------------------------- 1 | package com.github.shiraji.emoji.data 2 | 3 | object EmojiDataManager { 4 | val emojiList: MutableList = mutableListOf() 5 | } -------------------------------------------------------------------------------- /.idea/vcs.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | -------------------------------------------------------------------------------- /.idea/kotlinScripting.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 6 | -------------------------------------------------------------------------------- /.idea/kotlinc.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 7 | -------------------------------------------------------------------------------- /LATEST.txt: -------------------------------------------------------------------------------- 1 |

3.1.1

2 | 6 |

Older version changes are listed on CHANGELOG.md

-------------------------------------------------------------------------------- /src/main/kotlin/com/github/shiraji/emoji/data/EmojiData.kt: -------------------------------------------------------------------------------- 1 | package com.github.shiraji.emoji.data 2 | 3 | import javax.swing.Icon 4 | 5 | data class EmojiData( 6 | val label: String, 7 | val url: String, 8 | val unicode: String?, 9 | val icon: Icon? 10 | ) -------------------------------------------------------------------------------- /gradle/wrapper/gradle-wrapper.properties: -------------------------------------------------------------------------------- 1 | #Tue Oct 11 01:17:35 JST 2016 2 | distributionBase=GRADLE_USER_HOME 3 | distributionPath=wrapper/dists 4 | zipStoreBase=GRADLE_USER_HOME 5 | zipStorePath=wrapper/dists 6 | distributionUrl=https\://services.gradle.org/distributions/gradle-6.2.2-all.zip 7 | -------------------------------------------------------------------------------- /.idea/compiler.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | -------------------------------------------------------------------------------- /src/main/kotlin/com/github/shiraji/emoji/contributor/MarkdownEmojiCompletionContributor.kt: -------------------------------------------------------------------------------- 1 | package com.github.shiraji.emoji.contributor 2 | 3 | import com.github.shiraji.emoji.data.pattern.markdownPattern 4 | 5 | class MarkdownEmojiCompletionContributor : EmojiCompletionContributor() { 6 | override val place = markdownPattern 7 | } 8 | -------------------------------------------------------------------------------- /RELEASING.md: -------------------------------------------------------------------------------- 1 | # To release beta channel 2 | 3 | * Create a tag with prefix `beta-` e.g. `beta-1.0.1` publish the plugin version 1.0.1 to beta channel 4 | 5 | # To release stable channel 6 | 7 | * Update CHANGELOG.md 8 | * Update LATEST.txt 9 | * Create a tag with prefix `release-` e.g. `release-1.0.1` publish the plugin version 1.0.1 to stable channel -------------------------------------------------------------------------------- /local.properties: -------------------------------------------------------------------------------- 1 | ## This file must *NOT* be checked into Version Control Systems, 2 | # as it contains information specific to your local configuration. 3 | # 4 | # Location of the SDK. This is only used by Gradle. 5 | # For customization when using a Version Control System, please read the 6 | # header note. 7 | #Sun Apr 05 01:26:35 JST 2020 8 | sdk.dir=/Users/isogai/Library/Android/sdk 9 | -------------------------------------------------------------------------------- /src/main/kotlin/com/github/shiraji/emoji/data/pattern/PsiPlainTextPattern.kt: -------------------------------------------------------------------------------- 1 | package com.github.shiraji.emoji.data.pattern 2 | 3 | import com.intellij.patterns.ElementPattern 4 | import com.intellij.patterns.PlatformPatterns 5 | import com.intellij.psi.PsiElement 6 | import com.intellij.psi.PsiPlainText 7 | 8 | val psiPlainTextPattern: ElementPattern = PlatformPatterns.psiElement(PsiPlainText::class.java) -------------------------------------------------------------------------------- /src/main/kotlin/com/github/shiraji/emoji/folding/MarkdownTextFoldingBuilder.kt: -------------------------------------------------------------------------------- 1 | package com.github.shiraji.emoji.folding 2 | 3 | import com.github.shiraji.emoji.data.pattern.markdownPattern 4 | import com.intellij.patterns.ElementPattern 5 | import com.intellij.psi.PsiElement 6 | 7 | class MarkdownTextFoldingBuilder : EmojiFoldingBuilder() { 8 | override val place: ElementPattern = markdownPattern 9 | } -------------------------------------------------------------------------------- /src/main/kotlin/com/github/shiraji/emoji/folding/PsiPlainTextFoldingBuilder.kt: -------------------------------------------------------------------------------- 1 | package com.github.shiraji.emoji.folding 2 | 3 | import com.github.shiraji.emoji.data.pattern.psiPlainTextPattern 4 | import com.intellij.patterns.ElementPattern 5 | import com.intellij.psi.PsiElement 6 | 7 | class PsiPlainTextFoldingBuilder : EmojiFoldingBuilder() { 8 | override val place: ElementPattern = psiPlainTextPattern 9 | } -------------------------------------------------------------------------------- /src/main/kotlin/com/github/shiraji/emoji/contributor/PsiPlainTextCompletionContributor.kt: -------------------------------------------------------------------------------- 1 | package com.github.shiraji.emoji.contributor 2 | 3 | import com.github.shiraji.emoji.data.pattern.psiPlainTextPattern 4 | import com.intellij.patterns.ElementPattern 5 | import com.intellij.psi.PsiElement 6 | 7 | class PsiPlainTextCompletionContributor : EmojiCompletionContributor() { 8 | override val place: ElementPattern = psiPlainTextPattern 9 | } -------------------------------------------------------------------------------- /src/main/resources/META-INF/markdown.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 5 | 6 | 7 | 8 | -------------------------------------------------------------------------------- /settings.gradle.kts: -------------------------------------------------------------------------------- 1 | rootProject.name = "emoji" 2 | 3 | pluginManagement { 4 | resolutionStrategy { 5 | val kotlinVersion: String by settings 6 | eachPlugin { 7 | when (requested.id.id) { 8 | "org.jetbrains.kotlin.jvm" -> useModule("org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlinVersion") 9 | } 10 | } 11 | } 12 | 13 | repositories { 14 | mavenCentral() 15 | maven(url = "https://plugins.gradle.org/m2/") 16 | } 17 | } -------------------------------------------------------------------------------- /.idea/modules.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | -------------------------------------------------------------------------------- /src/main/kotlin/com/github/shiraji/emoji/data/pattern/MarkdownPattern.kt: -------------------------------------------------------------------------------- 1 | package com.github.shiraji.emoji.data.pattern 2 | 3 | import com.intellij.patterns.ElementPattern 4 | import com.intellij.patterns.PlatformPatterns 5 | import com.intellij.psi.PsiElement 6 | import org.intellij.plugins.markdown.lang.psi.impl.MarkdownCodeFenceImpl 7 | import org.intellij.plugins.markdown.lang.psi.impl.MarkdownFile 8 | 9 | val markdownPattern: ElementPattern = PlatformPatterns.psiElement().inside(MarkdownFile::class.java) 10 | .andNot(PlatformPatterns.psiElement().inside(MarkdownCodeFenceImpl::class.java)) -------------------------------------------------------------------------------- /.github/FUNDING.yml: -------------------------------------------------------------------------------- 1 | # These are supported funding model platforms 2 | 3 | github: shiraji 4 | patreon: # Replace with a single Patreon username 5 | open_collective: # Replace with a single Open Collective username 6 | ko_fi: # Replace with a single Ko-fi username 7 | tidelift: # Replace with a single Tidelift platform-name/package-name e.g., npm/babel 8 | community_bridge: # Replace with a single Community Bridge project-name e.g., cloud-foundry 9 | liberapay: # Replace with a single Liberapay username 10 | issuehunt: # Replace with a single IssueHunt username 11 | otechie: # Replace with a single Otechie username 12 | custom: https://paypal.me/shiraji 13 | -------------------------------------------------------------------------------- /.idea/gradle.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 17 | 18 | -------------------------------------------------------------------------------- /src/main/kotlin/com/github/shiraji/emoji/action/EmojiPreloadingActivity.kt: -------------------------------------------------------------------------------- 1 | package com.github.shiraji.emoji.action 2 | 3 | import com.github.shiraji.emoji.data.EmojiDataManager 4 | import com.github.shiraji.emoji.service.EmojiReader 5 | import com.intellij.openapi.application.PreloadingActivity 6 | import com.intellij.openapi.application.ex.ApplicationUtil.runWithCheckCanceled 7 | import com.intellij.openapi.progress.ProgressIndicator 8 | 9 | class EmojiPreloadingActivity : PreloadingActivity() { 10 | override fun preload(indicator: ProgressIndicator) { 11 | EmojiDataManager.emojiList.clear() 12 | EmojiDataManager.emojiList.addAll(runWithCheckCanceled({ EmojiReader.loadEmoji() }, indicator)) 13 | } 14 | } -------------------------------------------------------------------------------- /src/main/kotlin/com/github/shiraji/emoji/listener/EmojiDynamicPluginListener.kt: -------------------------------------------------------------------------------- 1 | package com.github.shiraji.emoji.listener 2 | 3 | import com.github.shiraji.emoji.data.EmojiDataManager 4 | import com.github.shiraji.emoji.service.EmojiReader 5 | import com.intellij.ide.plugins.DynamicPluginListener 6 | import com.intellij.ide.plugins.IdeaPluginDescriptor 7 | 8 | class EmojiDynamicPluginListener : DynamicPluginListener { 9 | 10 | override fun pluginLoaded(pluginDescriptor: IdeaPluginDescriptor) { 11 | if (pluginDescriptor.pluginId.idString == "com.github.shiraji.emoji" && EmojiDataManager.emojiList.isEmpty()) { 12 | EmojiDataManager.emojiList.addAll(EmojiReader.loadEmoji()) 13 | } 14 | } 15 | } -------------------------------------------------------------------------------- /.idea/modules/emoji.iml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | -------------------------------------------------------------------------------- /src/main/kotlin/com/github/shiraji/emoji/ext/CompletionParameters.kt: -------------------------------------------------------------------------------- 1 | package com.github.shiraji.emoji.ext 2 | 3 | import com.intellij.codeInsight.completion.CompletionParameters 4 | 5 | fun CompletionParameters.findColonPosition(): Int { 6 | val start = this.editor.caretModel.currentCaret.offset - 1 7 | val end = maxOf(this.position.textRange.startOffset - 1, 0) 8 | val text = this.editor.document.text 9 | var colonPosition = -1 10 | loop@ for (index in start downTo end) { 11 | val current = text[index] 12 | when { 13 | current.isWhitespace() -> return -1 14 | current == ':' -> { 15 | colonPosition = index 16 | break@loop 17 | } 18 | index == end -> return -1 19 | } 20 | } 21 | return colonPosition 22 | } -------------------------------------------------------------------------------- /.idea/runConfigurations/Emoji_Support_Plugin__buildPlugin_.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 11 | 16 | 18 | 19 | 20 | -------------------------------------------------------------------------------- /.idea/misc.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 1.8 14 | 15 | 20 | 21 | 22 | 23 | 24 | 25 | -------------------------------------------------------------------------------- /.idea/runConfigurations/Emoji_Support_Plugin__runIde_.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 11 | 16 | 18 | true 19 | 20 | 21 | -------------------------------------------------------------------------------- /CHANGELOG.md: -------------------------------------------------------------------------------- 1 | ### [release-3.1.1](https://github.com/shiraji/emoji/releases/tag/release-3.1.1) 2 | 3 | * Support Dynamic Load 4 | * Fix UninitializedPropertyAccessException #32 and #34 5 | 6 | ### [release-3.1.0](https://github.com/shiraji/emoji/releases/tag/release-3.1.0) 7 | 8 | * Support code folding #1 9 | * Add plugin icon #27 10 | 11 | ### [release-3.0.0](https://github.com/shiraji/emoji/releases/tag/release-3.0.0) 12 | 13 | * Reimplement this plugin. Now this plugin uses GitHub Emoji API 14 | * Support markdown 15 | 16 | ### [ver 2.0.1](https://github.com/shiraji/emoji/releases/tag/v2.0.1) 17 | 18 | * Retina support #7 19 | 20 | ### [ver 2.0.0](https://github.com/shiraji/emoji/releases/tag/v2.0.0) 21 | 22 | * ':' requires for completion [#4] 23 | 24 | ### [ver 1.0.1](https://github.com/shiraji/emoji/releases/tag/v1.0.1) 25 | 26 | * Fix a problem with "Find in Path" dialog [#2] 27 | 28 | ### [ver 1.0.0](https://github.com/shiraji/emoji/releases/tag/v1.0.0) 29 | 30 | * Initial release 31 | -------------------------------------------------------------------------------- /src/main/kotlin/com/github/shiraji/emoji/service/EmojiReader.kt: -------------------------------------------------------------------------------- 1 | package com.github.shiraji.emoji.service 2 | 3 | import com.github.shiraji.emoji.data.EmojiData 4 | import com.google.gson.Gson 5 | import com.intellij.ui.scale.JBUIScale 6 | import com.intellij.util.IconUtil 7 | import javax.swing.JLabel 8 | 9 | object EmojiReader { 10 | fun loadEmoji(): List { 11 | javaClass.getResourceAsStream("/emoji.json").use { inputStream -> 12 | val text = inputStream.bufferedReader().readText() 13 | return Gson().fromJson(text, Map::class.java).map { 14 | val url = it.value.toString() 15 | // e.g. https://github.githubassets.com/images/icons/emoji/unicode/1f1e6-1f1eb.png?v8 16 | val hex = url.substringAfterLast("/").substringBefore(".") 17 | try { 18 | val codePoints = hex.split("-").map { code -> Integer.decode("0x$code") }.toIntArray() 19 | val unicode = String(codePoints, 0, codePoints.size) 20 | val icon = if (codePoints.size == 1) IconUtil.textToIcon(unicode, JLabel(), JBUIScale.scale(11f)) else null 21 | EmojiData(label = it.key.toString(), url = url, icon = icon, unicode = unicode) 22 | } catch (e: NumberFormatException) { 23 | // Emoji without unicode URL. e.g. GitHub original emoji 24 | EmojiData(label = it.key.toString(), url = url, icon = null, unicode = null) 25 | } 26 | } 27 | } 28 | } 29 | } -------------------------------------------------------------------------------- /src/main/kotlin/com/github/shiraji/emoji/completion/EmojiCompletionProvider.kt: -------------------------------------------------------------------------------- 1 | package com.github.shiraji.emoji.completion 2 | 3 | import com.github.shiraji.emoji.data.EmojiDataManager 4 | import com.github.shiraji.emoji.ext.findColonPosition 5 | import com.github.shiraji.emoji.service.EmojiReader 6 | import com.intellij.codeInsight.completion.CompletionParameters 7 | import com.intellij.codeInsight.completion.CompletionProvider 8 | import com.intellij.codeInsight.completion.CompletionResultSet 9 | import com.intellij.codeInsight.lookup.LookupElementBuilder 10 | import com.intellij.util.ProcessingContext 11 | 12 | class EmojiCompletionProvider : CompletionProvider() { 13 | override fun addCompletions( 14 | parameters: CompletionParameters, 15 | context: ProcessingContext, 16 | result: CompletionResultSet 17 | ) { 18 | if (parameters.editor.isOneLineMode) return 19 | val colonPosition = parameters.findColonPosition() 20 | if (colonPosition < 0) return 21 | 22 | if (EmojiDataManager.emojiList.isEmpty()) { 23 | EmojiDataManager.emojiList.addAll(EmojiReader.loadEmoji()) 24 | } 25 | 26 | EmojiDataManager.emojiList.forEach { 27 | result.addElement(LookupElementBuilder.create(":${it.label}: ${it.unicode ?: ""}") 28 | .withIcon(it.icon) 29 | .withInsertHandler { insertionContext, _ -> 30 | insertionContext.document.replaceString(colonPosition, insertionContext.tailOffset, ":${it.label}: ") 31 | } 32 | ) 33 | } 34 | } 35 | } -------------------------------------------------------------------------------- /.idea/jarRepositories.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 9 | 10 | 14 | 15 | 19 | 20 | 24 | 25 | 29 | 30 | 34 | 35 | -------------------------------------------------------------------------------- /src/main/resources/META-INF/pluginIcon.svg: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | background 5 | 6 | 7 | 8 | 9 | 10 | Layer 1 11 | : 12 | + 13 | : 14 | 1 15 | 16 | -------------------------------------------------------------------------------- /src/main/kotlin/com/github/shiraji/emoji/contributor/EmojiCompletionContributor.kt: -------------------------------------------------------------------------------- 1 | package com.github.shiraji.emoji.contributor 2 | 3 | import com.github.shiraji.emoji.completion.EmojiCompletionProvider 4 | import com.github.shiraji.emoji.ext.findColonPosition 5 | import com.intellij.codeInsight.completion.CompletionContributor 6 | import com.intellij.codeInsight.completion.CompletionParameters 7 | import com.intellij.codeInsight.completion.CompletionProvider 8 | import com.intellij.codeInsight.completion.CompletionResultSet 9 | import com.intellij.codeInsight.completion.CompletionType 10 | import com.intellij.openapi.util.TextRange 11 | import com.intellij.patterns.ElementPattern 12 | import com.intellij.psi.PsiElement 13 | import com.intellij.util.ProcessingContext 14 | 15 | abstract class EmojiCompletionContributor( 16 | private val provider: CompletionProvider = EmojiCompletionProvider() 17 | ) : CompletionContributor() { 18 | abstract val place: ElementPattern 19 | 20 | override fun fillCompletionVariants(parameters: CompletionParameters, result: CompletionResultSet) { 21 | super.fillCompletionVariants(parameters, result) 22 | if (parameters.completionType == CompletionType.BASIC && place.accepts(parameters.position)) { 23 | val colonPosition = parameters.findColonPosition() 24 | val newResult = if (colonPosition >= 0) { 25 | val prefix = parameters.editor.document.getText(TextRange(colonPosition, parameters.editor.caretModel.currentCaret.offset)) 26 | result.withPrefixMatcher(prefix) 27 | } else { 28 | result 29 | } 30 | provider.addCompletionVariants(parameters, ProcessingContext(), newResult) 31 | } 32 | } 33 | } -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | [![Software License](https://img.shields.io/badge/license-Apache%202.0-brightgreen.svg)](https://github.com/shiraji/find-pull-request/blob/master/LICENSE) 2 | [![Version](https://img.shields.io/jetbrains/plugin/v/12512-yet-another-emoji-support.svg)](https://plugins.jetbrains.com/plugin/9174-emoji-support-plugin) 3 | [![Download](https://img.shields.io/jetbrains/plugin/d/12512-yet-another-emoji-support.svg)](https://plugins.jetbrains.com/plugin/9174-emoji-support-plugin) 4 | 5 | ![icon](.idea/icon.png) 6 | 7 | # Emoji Support Plugin 8 | 9 | Intellij plugin for supporting auto-complete for Emoji. This plugin is useful for filling in Emoji for commit messages. 10 | 11 | ## How to use it? 12 | 13 | 1. Type ":" and emoji name 14 | 1. Open code completion 15 | 16 | ![commit](website/images/commit.gif) 17 | 18 | ## Code Folding 19 | 20 | This plugin provides code folding for emoji. 21 | 22 | ![code_folding](website/images/code_folding.gif) 23 | 24 | ## Supported inserting location 25 | 26 | * IntelliJ Commit Message 27 | 28 | The list of supported languages are: 29 | 30 | * Markdown 31 | 32 | See [#20](https://github.com/shiraji/emoji/issues/20) for other languages 33 | 34 | ## How to install 35 | 36 | Use the IDE's plugin manager to install the latest version of the plugin. 37 | 38 | ## LICENSE 39 | 40 | ``` 41 | Copyright 2020 Yoshinori Isogai 42 | 43 | Licensed under the Apache License, Version 2.0 (the "License"); 44 | you may not use this file except in compliance with the License. 45 | You may obtain a copy of the License at 46 | 47 | http://www.apache.org/licenses/LICENSE-2.0 48 | 49 | Unless required by applicable law or agreed to in writing, software 50 | distributed under the License is distributed on an "AS IS" BASIS, 51 | WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 52 | See the License for the specific language governing permissions and 53 | limitations under the License. 54 | ``` 55 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | .env 2 | .gradle 3 | .DS_Store 4 | /build/ 5 | !gradle/wrapper/gradle-wrapper.jar 6 | src/main/resources/emoji.json 7 | 8 | ### STS ### 9 | .apt_generated 10 | .classpath 11 | .factorypath 12 | .project 13 | .settings 14 | .springBeans 15 | .sts4-cache 16 | 17 | ### IntelliJ IDEA ### 18 | *.iws 19 | *.ipr 20 | /out/ 21 | 22 | ### NetBeans ### 23 | /nbproject/private/ 24 | /nbbuild/ 25 | /dist/ 26 | /nbdist/ 27 | /.nb-gradle/ 28 | 29 | # https://github.com/github/gitignore/blob/master/Global/JetBrains.gitignore をベースとして変更したもの 30 | 31 | # Covers JetBrains IDEs: IntelliJ, RubyMine, PhpStorm, AppCode, PyCharm, CLion, Android Studio and WebStorm 32 | # Reference: https://intellij-support.jetbrains.com/hc/en-us/articles/206544839 33 | 34 | # User-specific stuff 35 | .idea/**/workspace.xml 36 | .idea/**/tasks.xml 37 | .idea/**/usage.statistics.xml 38 | .idea/**/dictionaries/* 39 | !.idea/**/dictionaries/project.xml 40 | .idea/**/shelf 41 | 42 | # Generated files 43 | .idea/**/contentModel.xml 44 | 45 | # Sensitive or high-churn files 46 | .idea/**/dataSources/ 47 | .idea/**/dataSources.ids 48 | .idea/**/dataSources.local.xml 49 | .idea/**/sqlDataSources.xml 50 | .idea/**/dynamic.xml 51 | .idea/**/uiDesigner.xml 52 | .idea/**/dbnavigator.xml 53 | 54 | # IntelliJ IDEA with Gradle or Maven 55 | # See : https://intellij-support.jetbrains.com/hc/en-us/articles/206544839-How-to-manage-projects-under-Version-Control-Systems 56 | .idea/**/gradle.xml 57 | .idea/libraries/ 58 | .idea/modules.xml 59 | *.iml 60 | 61 | # CMake 62 | cmake-build-*/ 63 | 64 | # Mongo Explorer plugin 65 | .idea/**/mongoSettings.xml 66 | 67 | # File-based project format 68 | *.iws 69 | 70 | # IntelliJ 71 | out/ 72 | 73 | # mpeltonen/sbt-idea plugin 74 | .idea_modules/ 75 | 76 | # JIRA plugin 77 | atlassian-ide-plugin.xml 78 | 79 | # Cursive Clojure plugin 80 | .idea/replstate.xml 81 | 82 | # Crashlytics plugin (for Android Studio and IntelliJ) 83 | com_crashlytics_export_strings.xml 84 | crashlytics.properties 85 | crashlytics-build.properties 86 | fabric.properties 87 | 88 | # Editor-based Rest Client 89 | .idea/httpRequests -------------------------------------------------------------------------------- /src/main/kotlin/com/github/shiraji/emoji/folding/EmojiFoldingBuilder.kt: -------------------------------------------------------------------------------- 1 | package com.github.shiraji.emoji.folding 2 | 3 | import com.github.shiraji.emoji.data.EmojiDataManager 4 | import com.intellij.lang.ASTNode 5 | import com.intellij.lang.folding.FoldingBuilderEx 6 | import com.intellij.lang.folding.FoldingDescriptor 7 | import com.intellij.openapi.editor.Document 8 | import com.intellij.openapi.util.TextRange 9 | import com.intellij.patterns.ElementPattern 10 | import com.intellij.psi.PsiElement 11 | 12 | abstract class EmojiFoldingBuilder : FoldingBuilderEx() { 13 | 14 | abstract val place: ElementPattern 15 | 16 | // This should match with 'emojiKeyRegex' in build.gradle.kts 17 | private val regex = Regex(":([a-z0-9_+\\\\-]+):") 18 | 19 | override fun getPlaceholderText(node: ASTNode, range: TextRange): String? { 20 | val label = range.substring(node.text).replace(":", "") 21 | val unicode = EmojiDataManager.emojiList.firstOrNull { it.label == label }?.unicode ?: return null 22 | return " $unicode " 23 | } 24 | 25 | override fun buildFoldRegions(root: PsiElement, document: Document, quick: Boolean): Array { 26 | val list = mutableListOf() 27 | regex.findAll(root.text).forEach { matchResult -> 28 | if (matchResult.groups.size >= 2 && EmojiDataManager.emojiList.firstOrNull { it.label == matchResult.groups[1]?.value } != null) { 29 | val element = root.findElementAt(TextRange(matchResult.range.first, matchResult.range.last + 1)) ?: return@forEach 30 | if (place.accepts(element)) { 31 | list.add(FoldingDescriptor(root, TextRange(matchResult.range.first, matchResult.range.last + 1))) 32 | } 33 | } 34 | } 35 | return list.toTypedArray() 36 | } 37 | 38 | private fun PsiElement.findElementAt(range: TextRange): PsiElement? { 39 | var element = findElementAt(range.startOffset) ?: return null 40 | while (!element.textRange.contains(range)) { 41 | if (element == this) return null 42 | element = element.parent 43 | } 44 | return element 45 | } 46 | 47 | override fun getPlaceholderText(node: ASTNode): String? { 48 | return null 49 | } 50 | 51 | override fun isCollapsedByDefault(node: ASTNode): Boolean { 52 | return true 53 | } 54 | } -------------------------------------------------------------------------------- /gradlew.bat: -------------------------------------------------------------------------------- 1 | @if "%DEBUG%" == "" @echo off 2 | @rem ########################################################################## 3 | @rem 4 | @rem Gradle startup script for Windows 5 | @rem 6 | @rem ########################################################################## 7 | 8 | @rem Set local scope for the variables with windows NT shell 9 | if "%OS%"=="Windows_NT" setlocal 10 | 11 | set DIRNAME=%~dp0 12 | if "%DIRNAME%" == "" set DIRNAME=. 13 | set APP_BASE_NAME=%~n0 14 | set APP_HOME=%DIRNAME% 15 | 16 | @rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. 17 | set DEFAULT_JVM_OPTS= 18 | 19 | @rem Find java.exe 20 | if defined JAVA_HOME goto findJavaFromJavaHome 21 | 22 | set JAVA_EXE=java.exe 23 | %JAVA_EXE% -version >NUL 2>&1 24 | if "%ERRORLEVEL%" == "0" goto init 25 | 26 | echo. 27 | echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. 28 | echo. 29 | echo Please set the JAVA_HOME variable in your environment to match the 30 | echo location of your Java installation. 31 | 32 | goto fail 33 | 34 | :findJavaFromJavaHome 35 | set JAVA_HOME=%JAVA_HOME:"=% 36 | set JAVA_EXE=%JAVA_HOME%/bin/java.exe 37 | 38 | if exist "%JAVA_EXE%" goto init 39 | 40 | echo. 41 | echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% 42 | echo. 43 | echo Please set the JAVA_HOME variable in your environment to match the 44 | echo location of your Java installation. 45 | 46 | goto fail 47 | 48 | :init 49 | @rem Get command-line arguments, handling Windows variants 50 | 51 | if not "%OS%" == "Windows_NT" goto win9xME_args 52 | if "%@eval[2+2]" == "4" goto 4NT_args 53 | 54 | :win9xME_args 55 | @rem Slurp the command line arguments. 56 | set CMD_LINE_ARGS= 57 | set _SKIP=2 58 | 59 | :win9xME_args_slurp 60 | if "x%~1" == "x" goto execute 61 | 62 | set CMD_LINE_ARGS=%* 63 | goto execute 64 | 65 | :4NT_args 66 | @rem Get arguments from the 4NT Shell from JP Software 67 | set CMD_LINE_ARGS=%$ 68 | 69 | :execute 70 | @rem Setup the command line 71 | 72 | set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar 73 | 74 | @rem Execute Gradle 75 | "%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS% 76 | 77 | :end 78 | @rem End local scope for the variables with windows NT shell 79 | if "%ERRORLEVEL%"=="0" goto mainEnd 80 | 81 | :fail 82 | rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of 83 | rem the _cmd.exe /c_ return code! 84 | if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1 85 | exit /b 1 86 | 87 | :mainEnd 88 | if "%OS%"=="Windows_NT" endlocal 89 | 90 | :omega 91 | -------------------------------------------------------------------------------- /.github/workflows/workflow.yml: -------------------------------------------------------------------------------- 1 | name: CI-test 2 | 3 | on: [push, pull_request] 4 | 5 | jobs: 6 | build-and-test: 7 | runs-on: ubuntu-latest 8 | steps: 9 | - uses: actions/checkout@v1 10 | - uses: actions/cache@v1 11 | with: 12 | path: ~/.gradle/caches 13 | key: v1-gradle-caches-${{ hashFiles('settings.gradle.kts') }}-${{ hashFiles('build.gradle.kts') }}-${{ hashFiles('gradle.properties') }} 14 | - uses: actions/cache@v1 15 | with: 16 | path: ~/.gradle/wrapper 17 | key: v1-gradle-wrapper-${{ hashFiles('settings.gradle.kts') }}-${{ hashFiles('build.gradle.kts') }}-${{ hashFiles('gradle.properties') }} 18 | - name: DL all dependencies 19 | run: ./gradlew resolveDependencies 20 | - name: ktlint and verify plugin 21 | run: ./gradlew ktlintCheck verifyPlugin --no-daemon --max-workers 2 22 | - name: test 23 | run: ./gradlew test jacocoTestReport --no-daemon --max-workers 2 24 | 25 | beta-release: 26 | needs: build-and-test 27 | runs-on: ubuntu-latest 28 | if: startswith(github.ref, 'refs/tags/beta-') 29 | steps: 30 | - uses: actions/checkout@v1 31 | - uses: actions/cache@v1 32 | with: 33 | path: ~/.gradle/caches 34 | key: v1-gradle-caches-${{ hashFiles('settings.gradle.kts') }}-${{ hashFiles('build.gradle.kts') }}-${{ hashFiles('gradle.properties') }} 35 | - uses: actions/cache@v1 36 | with: 37 | path: ~/.gradle/wrapper 38 | key: v1-gradle-wrapper-${{ hashFiles('settings.gradle.kts') }}-${{ hashFiles('build.gradle.kts') }}-${{ hashFiles('gradle.properties') }} 39 | - name: Release 40 | env: 41 | TAG_NAME: ${{ github.ref }} 42 | HUB_TOKEN: ${{ secrets.HUB_TOKEN }} 43 | run: ./gradlew buildPlugin publishPlugin -DVERSION=${TAG_NAME#refs/tags/beta-} -DCHANNELS=beta 44 | 45 | release: 46 | needs: build-and-test 47 | runs-on: ubuntu-latest 48 | if: startsWith(github.ref, 'refs/tags/release-') 49 | steps: 50 | - uses: actions/checkout@v1 51 | - uses: actions/cache@v1 52 | with: 53 | path: ~/.gradle/caches 54 | key: v1-gradle-caches-${{ hashFiles('settings.gradle.kts') }}-${{ hashFiles('build.gradle.kts') }}-${{ hashFiles('gradle.properties') }} 55 | - uses: actions/cache@v1 56 | with: 57 | path: ~/.gradle/wrapper 58 | key: v1-gradle-wrapper-${{ hashFiles('settings.gradle.kts') }}-${{ hashFiles('build.gradle.kts') }}-${{ hashFiles('gradle.properties') }} 59 | - name: Release 60 | env: 61 | TAG_NAME: ${{ github.ref }} 62 | HUB_TOKEN: ${{ secrets.HUB_TOKEN }} 63 | run: ./gradlew buildPlugin publishPlugin -DVERSION=${TAG_NAME#refs/tags/release-} -DCHANNELS=default 64 | -------------------------------------------------------------------------------- /.idea/libraries-with-intellij-classes.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 64 | 65 | -------------------------------------------------------------------------------- /src/main/resources/META-INF/plugin.xml: -------------------------------------------------------------------------------- 1 | 2 | com.github.shiraji.emoji 3 | Emoji Support Plugin 4 | Shiraji 5 | 6 | 8 |
9 | This plugin also supports code folding
10 | 11 | ]]>
12 | 13 | 14 | 15 | com.intellij.modules.lang 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | org.intellij.plugins.markdown 27 | 28 | 29 | 30 | 31 | 32 | 33 | 34 | 35 | 38 | 39 | 40 | 41 | 42 | 43 | 44 | 45 | 46 | 47 | 48 | 49 | 50 | 51 | 52 | 53 | 54 | 55 |
56 | -------------------------------------------------------------------------------- /gradlew: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env bash 2 | 3 | ############################################################################## 4 | ## 5 | ## Gradle start up script for UN*X 6 | ## 7 | ############################################################################## 8 | 9 | # Attempt to set APP_HOME 10 | # Resolve links: $0 may be a link 11 | PRG="$0" 12 | # Need this for relative symlinks. 13 | while [ -h "$PRG" ] ; do 14 | ls=`ls -ld "$PRG"` 15 | link=`expr "$ls" : '.*-> \(.*\)$'` 16 | if expr "$link" : '/.*' > /dev/null; then 17 | PRG="$link" 18 | else 19 | PRG=`dirname "$PRG"`"/$link" 20 | fi 21 | done 22 | SAVED="`pwd`" 23 | cd "`dirname \"$PRG\"`/" >/dev/null 24 | APP_HOME="`pwd -P`" 25 | cd "$SAVED" >/dev/null 26 | 27 | APP_NAME="Gradle" 28 | APP_BASE_NAME=`basename "$0"` 29 | 30 | # Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. 31 | DEFAULT_JVM_OPTS="" 32 | 33 | # Use the maximum available, or set MAX_FD != -1 to use that value. 34 | MAX_FD="maximum" 35 | 36 | warn ( ) { 37 | echo "$*" 38 | } 39 | 40 | die ( ) { 41 | echo 42 | echo "$*" 43 | echo 44 | exit 1 45 | } 46 | 47 | # OS specific support (must be 'true' or 'false'). 48 | cygwin=false 49 | msys=false 50 | darwin=false 51 | nonstop=false 52 | case "`uname`" in 53 | CYGWIN* ) 54 | cygwin=true 55 | ;; 56 | Darwin* ) 57 | darwin=true 58 | ;; 59 | MINGW* ) 60 | msys=true 61 | ;; 62 | NONSTOP* ) 63 | nonstop=true 64 | ;; 65 | esac 66 | 67 | CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar 68 | 69 | # Determine the Java command to use to start the JVM. 70 | if [ -n "$JAVA_HOME" ] ; then 71 | if [ -x "$JAVA_HOME/jre/sh/java" ] ; then 72 | # IBM's JDK on AIX uses strange locations for the executables 73 | JAVACMD="$JAVA_HOME/jre/sh/java" 74 | else 75 | JAVACMD="$JAVA_HOME/bin/java" 76 | fi 77 | if [ ! -x "$JAVACMD" ] ; then 78 | die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME 79 | 80 | Please set the JAVA_HOME variable in your environment to match the 81 | location of your Java installation." 82 | fi 83 | else 84 | JAVACMD="java" 85 | which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. 86 | 87 | Please set the JAVA_HOME variable in your environment to match the 88 | location of your Java installation." 89 | fi 90 | 91 | # Increase the maximum file descriptors if we can. 92 | if [ "$cygwin" = "false" -a "$darwin" = "false" -a "$nonstop" = "false" ] ; then 93 | MAX_FD_LIMIT=`ulimit -H -n` 94 | if [ $? -eq 0 ] ; then 95 | if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then 96 | MAX_FD="$MAX_FD_LIMIT" 97 | fi 98 | ulimit -n $MAX_FD 99 | if [ $? -ne 0 ] ; then 100 | warn "Could not set maximum file descriptor limit: $MAX_FD" 101 | fi 102 | else 103 | warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT" 104 | fi 105 | fi 106 | 107 | # For Darwin, add options to specify how the application appears in the dock 108 | if $darwin; then 109 | GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\"" 110 | fi 111 | 112 | # For Cygwin, switch paths to Windows format before running java 113 | if $cygwin ; then 114 | APP_HOME=`cygpath --path --mixed "$APP_HOME"` 115 | CLASSPATH=`cygpath --path --mixed "$CLASSPATH"` 116 | JAVACMD=`cygpath --unix "$JAVACMD"` 117 | 118 | # We build the pattern for arguments to be converted via cygpath 119 | ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null` 120 | SEP="" 121 | for dir in $ROOTDIRSRAW ; do 122 | ROOTDIRS="$ROOTDIRS$SEP$dir" 123 | SEP="|" 124 | done 125 | OURCYGPATTERN="(^($ROOTDIRS))" 126 | # Add a user-defined pattern to the cygpath arguments 127 | if [ "$GRADLE_CYGPATTERN" != "" ] ; then 128 | OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)" 129 | fi 130 | # Now convert the arguments - kludge to limit ourselves to /bin/sh 131 | i=0 132 | for arg in "$@" ; do 133 | CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -` 134 | CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option 135 | 136 | if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition 137 | eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"` 138 | else 139 | eval `echo args$i`="\"$arg\"" 140 | fi 141 | i=$((i+1)) 142 | done 143 | case $i in 144 | (0) set -- ;; 145 | (1) set -- "$args0" ;; 146 | (2) set -- "$args0" "$args1" ;; 147 | (3) set -- "$args0" "$args1" "$args2" ;; 148 | (4) set -- "$args0" "$args1" "$args2" "$args3" ;; 149 | (5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;; 150 | (6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;; 151 | (7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;; 152 | (8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;; 153 | (9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;; 154 | esac 155 | fi 156 | 157 | # Split up the JVM_OPTS And GRADLE_OPTS values into an array, following the shell quoting and substitution rules 158 | function splitJvmOpts() { 159 | JVM_OPTS=("$@") 160 | } 161 | eval splitJvmOpts $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS 162 | JVM_OPTS[${#JVM_OPTS[*]}]="-Dorg.gradle.appname=$APP_BASE_NAME" 163 | 164 | exec "$JAVACMD" "${JVM_OPTS[@]}" -classpath "$CLASSPATH" org.gradle.wrapper.GradleWrapperMain "$@" 165 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | 2 | Apache License 3 | Version 2.0, January 2004 4 | http://www.apache.org/licenses/ 5 | 6 | TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION 7 | 8 | 1. Definitions. 9 | 10 | "License" shall mean the terms and conditions for use, reproduction, 11 | and distribution as defined by Sections 1 through 9 of this document. 12 | 13 | "Licensor" shall mean the copyright owner or entity authorized by 14 | the copyright owner that is granting the License. 15 | 16 | "Legal Entity" shall mean the union of the acting entity and all 17 | other entities that control, are controlled by, or are under common 18 | control with that entity. For the purposes of this definition, 19 | "control" means (i) the power, direct or indirect, to cause the 20 | direction or management of such entity, whether by contract or 21 | otherwise, or (ii) ownership of fifty percent (50%) or more of the 22 | outstanding shares, or (iii) beneficial ownership of such entity. 23 | 24 | "You" (or "Your") shall mean an individual or Legal Entity 25 | exercising permissions granted by this License. 26 | 27 | "Source" form shall mean the preferred form for making modifications, 28 | including but not limited to software source code, documentation 29 | source, and configuration files. 30 | 31 | "Object" form shall mean any form resulting from mechanical 32 | transformation or translation of a Source form, including but 33 | not limited to compiled object code, generated documentation, 34 | and conversions to other media types. 35 | 36 | "Work" shall mean the work of authorship, whether in Source or 37 | Object form, made available under the License, as indicated by a 38 | copyright notice that is included in or attached to the work 39 | (an example is provided in the Appendix below). 40 | 41 | "Derivative Works" shall mean any work, whether in Source or Object 42 | form, that is based on (or derived from) the Work and for which the 43 | editorial revisions, annotations, elaborations, or other modifications 44 | represent, as a whole, an original work of authorship. For the purposes 45 | of this License, Derivative Works shall not include works that remain 46 | separable from, or merely link (or bind by name) to the interfaces of, 47 | the Work and Derivative Works thereof. 48 | 49 | "Contribution" shall mean any work of authorship, including 50 | the original version of the Work and any modifications or additions 51 | to that Work or Derivative Works thereof, that is intentionally 52 | submitted to Licensor for inclusion in the Work by the copyright owner 53 | or by an individual or Legal Entity authorized to submit on behalf of 54 | the copyright owner. For the purposes of this definition, "submitted" 55 | means any form of electronic, verbal, or written communication sent 56 | to the Licensor or its representatives, including but not limited to 57 | communication on electronic mailing lists, source code control systems, 58 | and issue tracking systems that are managed by, or on behalf of, the 59 | Licensor for the purpose of discussing and improving the Work, but 60 | excluding communication that is conspicuously marked or otherwise 61 | designated in writing by the copyright owner as "Not a Contribution." 62 | 63 | "Contributor" shall mean Licensor and any individual or Legal Entity 64 | on behalf of whom a Contribution has been received by Licensor and 65 | subsequently incorporated within the Work. 66 | 67 | 2. Grant of Copyright License. Subject to the terms and conditions of 68 | this License, each Contributor hereby grants to You a perpetual, 69 | worldwide, non-exclusive, no-charge, royalty-free, irrevocable 70 | copyright license to reproduce, prepare Derivative Works of, 71 | publicly display, publicly perform, sublicense, and distribute the 72 | Work and such Derivative Works in Source or Object form. 73 | 74 | 3. Grant of Patent License. Subject to the terms and conditions of 75 | this License, each Contributor hereby grants to You a perpetual, 76 | worldwide, non-exclusive, no-charge, royalty-free, irrevocable 77 | (except as stated in this section) patent license to make, have made, 78 | use, offer to sell, sell, import, and otherwise transfer the Work, 79 | where such license applies only to those patent claims licensable 80 | by such Contributor that are necessarily infringed by their 81 | Contribution(s) alone or by combination of their Contribution(s) 82 | with the Work to which such Contribution(s) was submitted. If You 83 | institute patent litigation against any entity (including a 84 | cross-claim or counterclaim in a lawsuit) alleging that the Work 85 | or a Contribution incorporated within the Work constitutes direct 86 | or contributory patent infringement, then any patent licenses 87 | granted to You under this License for that Work shall terminate 88 | as of the date such litigation is filed. 89 | 90 | 4. Redistribution. You may reproduce and distribute copies of the 91 | Work or Derivative Works thereof in any medium, with or without 92 | modifications, and in Source or Object form, provided that You 93 | meet the following conditions: 94 | 95 | (a) You must give any other recipients of the Work or 96 | Derivative Works a copy of this License; and 97 | 98 | (b) You must cause any modified files to carry prominent notices 99 | stating that You changed the files; and 100 | 101 | (c) You must retain, in the Source form of any Derivative Works 102 | that You distribute, all copyright, patent, trademark, and 103 | attribution notices from the Source form of the Work, 104 | excluding those notices that do not pertain to any part of 105 | the Derivative Works; and 106 | 107 | (d) If the Work includes a "NOTICE" text file as part of its 108 | distribution, then any Derivative Works that You distribute must 109 | include a readable copy of the attribution notices contained 110 | within such NOTICE file, excluding those notices that do not 111 | pertain to any part of the Derivative Works, in at least one 112 | of the following places: within a NOTICE text file distributed 113 | as part of the Derivative Works; within the Source form or 114 | documentation, if provided along with the Derivative Works; or, 115 | within a display generated by the Derivative Works, if and 116 | wherever such third-party notices normally appear. The contents 117 | of the NOTICE file are for informational purposes only and 118 | do not modify the License. You may add Your own attribution 119 | notices within Derivative Works that You distribute, alongside 120 | or as an addendum to the NOTICE text from the Work, provided 121 | that such additional attribution notices cannot be construed 122 | as modifying the License. 123 | 124 | You may add Your own copyright statement to Your modifications and 125 | may provide additional or different license terms and conditions 126 | for use, reproduction, or distribution of Your modifications, or 127 | for any such Derivative Works as a whole, provided Your use, 128 | reproduction, and distribution of the Work otherwise complies with 129 | the conditions stated in this License. 130 | 131 | 5. Submission of Contributions. Unless You explicitly state otherwise, 132 | any Contribution intentionally submitted for inclusion in the Work 133 | by You to the Licensor shall be under the terms and conditions of 134 | this License, without any additional terms or conditions. 135 | Notwithstanding the above, nothing herein shall supersede or modify 136 | the terms of any separate license agreement you may have executed 137 | with Licensor regarding such Contributions. 138 | 139 | 6. Trademarks. This License does not grant permission to use the trade 140 | names, trademarks, service marks, or product names of the Licensor, 141 | except as required for reasonable and customary use in describing the 142 | origin of the Work and reproducing the content of the NOTICE file. 143 | 144 | 7. Disclaimer of Warranty. Unless required by applicable law or 145 | agreed to in writing, Licensor provides the Work (and each 146 | Contributor provides its Contributions) on an "AS IS" BASIS, 147 | WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or 148 | implied, including, without limitation, any warranties or conditions 149 | of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A 150 | PARTICULAR PURPOSE. You are solely responsible for determining the 151 | appropriateness of using or redistributing the Work and assume any 152 | risks associated with Your exercise of permissions under this License. 153 | 154 | 8. Limitation of Liability. In no event and under no legal theory, 155 | whether in tort (including negligence), contract, or otherwise, 156 | unless required by applicable law (such as deliberate and grossly 157 | negligent acts) or agreed to in writing, shall any Contributor be 158 | liable to You for damages, including any direct, indirect, special, 159 | incidental, or consequential damages of any character arising as a 160 | result of this License or out of the use or inability to use the 161 | Work (including but not limited to damages for loss of goodwill, 162 | work stoppage, computer failure or malfunction, or any and all 163 | other commercial damages or losses), even if such Contributor 164 | has been advised of the possibility of such damages. 165 | 166 | 9. Accepting Warranty or Additional Liability. While redistributing 167 | the Work or Derivative Works thereof, You may choose to offer, 168 | and charge a fee for, acceptance of support, warranty, indemnity, 169 | or other liability obligations and/or rights consistent with this 170 | License. However, in accepting such obligations, You may act only 171 | on Your own behalf and on Your sole responsibility, not on behalf 172 | of any other Contributor, and only if You agree to indemnify, 173 | defend, and hold each Contributor harmless for any liability 174 | incurred by, or claims asserted against, such Contributor by reason 175 | of your accepting any such warranty or additional liability. 176 | 177 | END OF TERMS AND CONDITIONS 178 | 179 | APPENDIX: How to apply the Apache License to your work. 180 | 181 | To apply the Apache License to your work, attach the following 182 | boilerplate notice, with the fields enclosed by brackets "[]" 183 | replaced with your own identifying information. (Don't include 184 | the brackets!) The text should be enclosed in the appropriate 185 | comment syntax for the file format. We also recommend that a 186 | file or class name and description of purpose be included on the 187 | same "printed page" as the copyright notice for easier 188 | identification within third-party archives. 189 | 190 | Copyright [yyyy] [name of copyright owner] 191 | 192 | Licensed under the Apache License, Version 2.0 (the "License"); 193 | you may not use this file except in compliance with the License. 194 | You may obtain a copy of the License at 195 | 196 | http://www.apache.org/licenses/LICENSE-2.0 197 | 198 | Unless required by applicable law or agreed to in writing, software 199 | distributed under the License is distributed on an "AS IS" BASIS, 200 | WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 201 | See the License for the specific language governing permissions and 202 | limitations under the License. 203 | 204 | -------------------------------------------------------------------------------- /.idea/modules/emoji_test.iml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 9 | 10 | 22 | 27 | 38 | 41 | 42 | 43 | 44 | 45 | 46 | 47 | 48 | 49 | 50 | 51 | 52 | 53 | 54 | 55 | 56 | 57 | 58 | 59 | 60 | 61 | 62 | 63 | 64 | 65 | 66 | 67 | 68 | 69 | 70 | 71 | 72 | 73 | 74 | 75 | 76 | 77 | 78 | 79 | 80 | 81 | 82 | 83 | 84 | 85 | 86 | 87 | 88 | 89 | 90 | 91 | 92 | 93 | 94 | 95 | 96 | 97 | 98 | 99 | 100 | 101 | 102 | 103 | 104 | 105 | 106 | 107 | 108 | 109 | 110 | 111 | 112 | 113 | 114 | 115 | 116 | 117 | 118 | 119 | 120 | 121 | 122 | 123 | 124 | 125 | 126 | 127 | 128 | 129 | 130 | 131 | 132 | 133 | 134 | 135 | 136 | 137 | 138 | 139 | 140 | 141 | 142 | 143 | 144 | 145 | 146 | 147 | 148 | 149 | 150 | 151 | 152 | 153 | 154 | 155 | 156 | 157 | 158 | 159 | 160 | 161 | 162 | 163 | 164 | 165 | 166 | 167 | 168 | 169 | 170 | 171 | 172 | 173 | 174 | 175 | 176 | 177 | 178 | 179 | 180 | 181 | 182 | 183 | 184 | 185 | 186 | 187 | 188 | 189 | 190 | 191 | 192 | 193 | 194 | 195 | 196 | 197 | 198 | 199 | 200 | 201 | 202 | 203 | 204 | 205 | 206 | 207 | 208 | 209 | 210 | 211 | 212 | 213 | 214 | 215 | 216 | 217 | 218 | 219 | 220 | 221 | 222 | 223 | 224 | 225 | 226 | 227 | 228 | 229 | 230 | 231 | 232 | 233 | 234 | 235 | 236 | 237 | 238 | 239 | 240 | 241 | 242 | 243 | 244 | 245 | 246 | 247 | 248 | 249 | 250 | 251 | 252 | 253 | 254 | 255 | 256 | 257 | 258 | 259 | 260 | 261 | 262 | 263 | 264 | 265 | 266 | 267 | 268 | 269 | 270 | 271 | 272 | 273 | 274 | 275 | 276 | 277 | 278 | 279 | 280 | 281 | 282 | 283 | 284 | 285 | 286 | 287 | 288 | 289 | 290 | 291 | 292 | 293 | 294 | 295 | 296 | 297 | 298 | 299 | 300 | 301 | 302 | 303 | 304 | 305 | 306 | 307 | 308 | 309 | 310 | 311 | 312 | 313 | 314 | 315 | 316 | 317 | 318 | 319 | 320 | 321 | 322 | 323 | 324 | 325 | 326 | 327 | 328 | 329 | 330 | 331 | 332 | 333 | 334 | 335 | 336 | 337 | 338 | 339 | 340 | 341 | 342 | 343 | 344 | 345 | 346 | 347 | 348 | 349 | 350 | 351 | 352 | 353 | 354 | 355 | 356 | 357 | 358 | 359 | 360 | 361 | 362 | 363 | 364 | 365 | 366 | 367 | 368 | 369 | 370 | 371 | 372 | 373 | 374 | 375 | 376 | 377 | 378 | 379 | 380 | 381 | 382 | 383 | 384 | 385 | 386 | 387 | 388 | 389 | 390 | 391 | 392 | 393 | 394 | 395 | 396 | 397 | 398 | 399 | 400 | 401 | 402 | 403 | 404 | 405 | 406 | 407 | 408 | 409 | 410 | 411 | 412 | 413 | 414 | 415 | 416 | 417 | 418 | 419 | 420 | 421 | 422 | 423 | 424 | 425 | 426 | 427 | 428 | 429 | 430 | 431 | 432 | 433 | 434 | 435 | 436 | 437 | 438 | 439 | 440 | 441 | 442 | 443 | 444 | 445 | 446 | 447 | 448 | 449 | 450 | 451 | 452 | 453 | 454 | 455 | 456 | 457 | 458 | 459 | 460 | 461 | 462 | 463 | 464 | 465 | 466 | 467 | 468 | 469 | 470 | 471 | 472 | 473 | 474 | 475 | 476 | 477 | 478 | 479 | 480 | 481 | 482 | 483 | 484 | 485 | 486 | 487 | 488 | 489 | 490 | 491 | 492 | 493 | 494 | 495 | 496 | 497 | 498 | 499 | 500 | --------------------------------------------------------------------------------