diff --git a/CHANGELOG b/CHANGELOG
index 422c6f07b150810c027b59f6f42f5b23ebe44454..2e12889cb70eb0ba36957d539d661e39e2a1bc90 100644
--- a/CHANGELOG
+++ b/CHANGELOG
@@ -1,6 +1,24 @@
 Please view this file on the master branch, on stable branches it's out of date.
 
-v 8.3.0 (unreleased)
+v 8.4.0 (unreleased)
+  - Implement new UI for group page
+  - Implement search inside emoji picker
+  - Add project permissions to all project API endpoints (Stan Hu)
+  - Expose Git's version in the admin area
+  - Add "Frequently used" category to emoji picker
+  - Add CAS support (tduehr)
+  - Add link to merge request on build detail page.
+
+v 8.3.2 (unreleased)
+  - Enable "Add key" button when user fills in a proper key
+
+v 8.3.1
+  - Fix Error 500 when global milestones have slashes (Stan Hu)
+  - Fix Error 500 when doing a search in dashboard before visiting any project (Stan Hu)
+  - Fix LDAP identity and user retrieval when special characters are used
+  - Move Sidekiq-cron configuration to gitlab.yml
+
+v 8.3.0
   - Bump rack-attack to 4.3.1 for security fix (Stan Hu)
   - API support for starred projects for authorized user (Zeger-Jan van de Weg)
   - Add open_issues_count to project API (Stan Hu)
@@ -8,6 +26,8 @@ v 8.3.0 (unreleased)
   - Add button to automatically merge a merge request when the build succeeds (Zeger-Jan van de Weg)
   - Provide better diagnostic message upon project creation errors (Stan Hu)
   - Bump devise to 3.5.3 to fix reset token expiring after account creation (Stan Hu)
+  - Remove api credentials from link to build_page
+  - Deprecate GitLabCiService making it to always be inactive
   - Bump gollum-lib to 4.1.0 (Stan Hu)
   - Fix broken group avatar upload under "New group" (Stan Hu)
   - Update project repositorize size and commit count during import:repos task (Stan Hu)
@@ -19,8 +39,10 @@ v 8.3.0 (unreleased)
   - Fix 500 error when update group member permission
   - Trim leading and trailing whitespace of milestone and issueable titles (Jose Corcuera)
   - Recognize issue/MR/snippet/commit links as references
+  - Backport JIRA features from EE to CE
   - Add ignore whitespace change option to commit view
   - Fire update hook from GitLab
+  - Allow account unlock via email
   - Style warning about mentioning many people in a comment
   - Fix: sort milestones by due date once again (Greg Smethells)
   - Migrate all CI::Services and CI::WebHooks to Services and WebHooks
diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md
index 7ced7c57889557f6da23e60a3a7c7e29fdfa3000..950824e35ab1095cdc78636b8813cfa977e5b77a 100644
--- a/CONTRIBUTING.md
+++ b/CONTRIBUTING.md
@@ -358,7 +358,7 @@ available at [http://contributor-covenant.org/version/1/1/0/](http://contributor
 [core team]: https://about.gitlab.com/core-team/
 [getting help page]: https://about.gitlab.com/getting-help/
 [Codetriage]: http://www.codetriage.com/gitlabhq/gitlabhq
-[up-for-grabs]: https://gitlab.com/gitlab-org/gitlab-ce/issues?label_name=up+for+grabs
+[up-for-grabs]: https://gitlab.com/gitlab-org/gitlab-ce/issues?label_name=up-for-grabs
 [medium-up-for-grabs]: https://medium.com/@kentcdodds/first-timers-only-78281ea47455
 [ce-tracker]: https://gitlab.com/gitlab-org/gitlab-ce/issues
 [ee-tracker]: https://gitlab.com/gitlab-org/gitlab-ee/issues
diff --git a/Gemfile b/Gemfile
index 76b4759499efdcba9969e1b4f876dd41dbae114b..db54bf2f186792f61d01a374a0f114c64ca6cac0 100644
--- a/Gemfile
+++ b/Gemfile
@@ -23,6 +23,7 @@ gem 'devise-async',           '~> 0.9.0'
 gem 'doorkeeper',             '~> 2.2.0'
 gem 'omniauth',               '~> 1.2.2'
 gem 'omniauth-bitbucket',     '~> 0.0.2'
+gem 'omniauth-cas3',          '~> 1.1.2'
 gem 'omniauth-facebook',      '~> 3.0.0'
 gem 'omniauth-github',        '~> 1.1.1'
 gem 'omniauth-gitlab',        '~> 1.0.0'
@@ -101,6 +102,9 @@ gem 'wikicloth',     '0.8.1'
 gem 'asciidoctor',   '~> 1.5.2'
 gem 'rouge',         '~> 1.10.1'
 
+# See https://groups.google.com/forum/#!topic/ruby-security-ann/aSbgDiwb24s
+gem 'nokogiri', '1.6.7.1'
+
 # Diffs
 gem 'diffy', '~> 3.0.3'
 
@@ -168,7 +172,7 @@ gem 'd3_rails', '~> 3.5.5'
 gem "cal-heatmap-rails", "~> 0.0.1"
 
 # underscore-rails
-gem "underscore-rails", "~> 1.4.4"
+gem "underscore-rails", "~> 1.8.0"
 
 # Sanitize user input
 gem "sanitize", '~> 2.0'
@@ -186,7 +190,7 @@ gem 'mousetrap-rails', '~> 1.4.6'
 # Detect and convert string character encoding
 gem 'charlock_holmes', '~> 0.7.3'
 
-gem "sass-rails", '~> 4.0.5'
+gem "sass-rails", '~> 5.0.0'
 gem "coffee-rails", '~> 4.1.0'
 gem "uglifier", '~> 2.7.2'
 gem 'turbolinks', '~> 2.5.0'
@@ -198,9 +202,9 @@ gem 'font-awesome-rails', '~> 4.2'
 gem 'gitlab_emoji',       '~> 0.2.0'
 gem 'gon',                '~> 6.0.1'
 gem 'jquery-atwho-rails', '~> 1.3.2'
-gem 'jquery-rails',       '~> 3.1.3'
+gem 'jquery-rails',       '~> 4.0.0'
 gem 'jquery-scrollto-rails', '~> 1.4.3'
-gem 'jquery-ui-rails',    '~> 4.2.1'
+gem 'jquery-ui-rails',    '~> 5.0.0'
 gem 'nprogress-rails',    '~> 0.1.6.7'
 gem 'raphael-rails',      '~> 2.1.2'
 gem 'request_store',      '~> 1.2.0'
diff --git a/Gemfile.lock b/Gemfile.lock
index 88c7a6e34241f11835e8506b7f4fe65f0814685f..4f4b10c0fb75550deea45f450bd3ae3698b24e62 100644
--- a/Gemfile.lock
+++ b/Gemfile.lock
@@ -372,15 +372,16 @@ GEM
     inflecto (0.0.2)
     ipaddress (0.8.0)
     jquery-atwho-rails (1.3.2)
-    jquery-rails (3.1.4)
-      railties (>= 3.0, < 5.0)
+    jquery-rails (4.0.5)
+      rails-dom-testing (~> 1.0)
+      railties (>= 4.2.0)
       thor (>= 0.14, < 2.0)
     jquery-scrollto-rails (1.4.3)
       railties (> 3.1, < 5.0)
     jquery-turbolinks (2.1.0)
       railties (>= 3.1.0)
       turbolinks
-    jquery-ui-rails (4.2.1)
+    jquery-ui-rails (5.0.5)
       railties (>= 3.2.16)
     json (1.8.3)
     jwt (1.5.2)
@@ -420,7 +421,7 @@ GEM
       grape
       newrelic_rpm
     newrelic_rpm (3.9.4.245)
-    nokogiri (1.6.7)
+    nokogiri (1.6.7.1)
       mini_portile2 (~> 2.0.0.rc2)
     nprogress-rails (0.1.6.7)
     oauth (0.4.7)
@@ -439,6 +440,10 @@ GEM
       multi_json (~> 1.7)
       omniauth (~> 1.1)
       omniauth-oauth (~> 1.0)
+    omniauth-cas3 (1.1.3)
+      addressable (~> 2.3)
+      nokogiri (~> 1.6.6)
+      omniauth (~> 1.2)
     omniauth-facebook (3.0.0)
       omniauth-oauth2 (~> 1.2)
     omniauth-github (1.1.2)
@@ -643,12 +648,13 @@ GEM
     safe_yaml (1.0.4)
     sanitize (2.1.0)
       nokogiri (>= 1.4.4)
-    sass (3.2.19)
-    sass-rails (4.0.5)
+    sass (3.4.20)
+    sass-rails (5.0.4)
       railties (>= 4.0.0, < 5.0)
-      sass (~> 3.2.2)
-      sprockets (~> 2.8, < 3.0)
-      sprockets-rails (~> 2.0)
+      sass (~> 3.1)
+      sprockets (>= 2.8, < 4.0)
+      sprockets-rails (>= 2.0, < 4.0)
+      tilt (>= 1.1, < 3)
     sawyer (0.6.0)
       addressable (~> 2.3.5)
       faraday (~> 0.8, < 0.10)
@@ -763,7 +769,7 @@ GEM
     uglifier (2.7.2)
       execjs (>= 0.3.0)
       json (>= 1.8.0)
-    underscore-rails (1.4.4)
+    underscore-rails (1.8.3)
     unf (0.1.4)
       unf_ext
     unf_ext (0.0.7.1)
@@ -874,10 +880,10 @@ DEPENDENCIES
   html-pipeline (~> 1.11.0)
   httparty (~> 0.13.3)
   jquery-atwho-rails (~> 1.3.2)
-  jquery-rails (~> 3.1.3)
+  jquery-rails (~> 4.0.0)
   jquery-scrollto-rails (~> 1.4.3)
   jquery-turbolinks (~> 2.1.0)
-  jquery-ui-rails (~> 4.2.1)
+  jquery-ui-rails (~> 5.0.0)
   kaminari (~> 0.16.3)
   letter_opener (~> 1.1.2)
   mail_room (~> 0.6.1)
@@ -888,11 +894,13 @@ DEPENDENCIES
   net-ssh (~> 3.0.1)
   newrelic-grape
   newrelic_rpm (~> 3.9.4.245)
+  nokogiri (= 1.6.7.1)
   nprogress-rails (~> 0.1.6.7)
   oauth2 (~> 1.0.0)
   octokit (~> 3.7.0)
   omniauth (~> 1.2.2)
   omniauth-bitbucket (~> 0.0.2)
+  omniauth-cas3 (~> 1.1.2)
   omniauth-facebook (~> 3.0.0)
   omniauth-github (~> 1.1.1)
   omniauth-gitlab (~> 1.0.0)
@@ -928,7 +936,7 @@ DEPENDENCIES
   rubocop (~> 0.35.0)
   ruby-fogbugz (~> 0.2.1)
   sanitize (~> 2.0)
-  sass-rails (~> 4.0.5)
+  sass-rails (~> 5.0.0)
   sdoc (~> 0.3.20)
   seed-fu (~> 2.3.5)
   select2-rails (~> 3.5.9)
@@ -957,7 +965,7 @@ DEPENDENCIES
   tinder (~> 1.10.0)
   turbolinks (~> 2.5.0)
   uglifier (~> 2.7.2)
-  underscore-rails (~> 1.4.4)
+  underscore-rails (~> 1.8.0)
   unf (~> 0.1.4)
   unicorn (~> 4.8.2)
   unicorn-worker-killer (~> 0.4.2)
diff --git a/VERSION b/VERSION
index 8d0676ff07ba5372063bb36af9529a8d976c16ad..ce669730119df83f8d693ec9e7401baf55b9245a 100644
--- a/VERSION
+++ b/VERSION
@@ -1 +1 @@
-8.3.0.pre
+8.4.0.pre
diff --git a/app/assets/images/emoji.png b/app/assets/images/emoji.png
new file mode 100644
index 0000000000000000000000000000000000000000..a8ad7b6eab612af71df106bf8ac26541a92fe217
Binary files /dev/null and b/app/assets/images/emoji.png differ
diff --git a/app/assets/javascripts/application.js.coffee b/app/assets/javascripts/application.js.coffee
index 1539eba0faa9e0ad0bb136cca26533492669c3e0..affab5bb030d8c72eba0fb7295f700cca0aecf1a 100644
--- a/app/assets/javascripts/application.js.coffee
+++ b/app/assets/javascripts/application.js.coffee
@@ -5,7 +5,7 @@
 # the compiled file.
 #
 #= require jquery
-#= require jquery.ui.all
+#= require jquery-ui
 #= require jquery_ujs
 #= require jquery.cookie
 #= require jquery.endless-scroll
diff --git a/app/assets/javascripts/awards_handler.coffee b/app/assets/javascripts/awards_handler.coffee
index 3ff9ba77dfc7fd77187b66aacfdaf73877f6390b..04bf5cc7bb5df0f6da653857dd4d8404278068c5 100644
--- a/app/assets/javascripts/awards_handler.coffee
+++ b/app/assets/javascripts/awards_handler.coffee
@@ -1,12 +1,28 @@
 class @AwardsHandler
   constructor: (@post_emoji_url, @noteable_type, @noteable_id, @aliases) ->
+    $(".add-award").click (event)->
+      event.stopPropagation()
+      event.preventDefault()
+      $(".emoji-menu").show()
+
+    $("html").click ->
+      if !$(event.target).closest(".emoji-menu").length
+        if $(".emoji-menu").is(":visible")
+          $(".emoji-menu").hide()
+
+    @renderFrequentlyUsedBlock()
+    @setupSearch()
 
   addAward: (emoji) ->
     emoji = @normilizeEmojiName(emoji)
     @postEmoji emoji, =>
       @addAwardToEmojiBar(emoji)
+
+    $(".emoji-menu").hide()
     
-  addAwardToEmojiBar: (emoji, custom_path = '') ->
+  addAwardToEmojiBar: (emoji) ->
+    @addEmojiToFrequentlyUsedList(emoji)
+
     emoji = @normilizeEmojiName(emoji)
     if @exist(emoji)
       if @isActive(emoji)
@@ -17,7 +33,7 @@ class @AwardsHandler
         counter.parent().addClass("active")
         @addMeToAuthorList(emoji)
     else
-      @createEmoji(emoji, custom_path)
+      @createEmoji(emoji)
 
   exist: (emoji) ->
     @findEmojiIcon(emoji).length > 0
@@ -54,35 +70,39 @@ class @AwardsHandler
   resetTooltip: (award) ->
     award.tooltip("destroy")
 
-    # "destroy" call is asynchronous, this is why we need to set timeout.
+    # "destroy" call is asynchronous and there is no appropriate callback on it, this is why we need to set timeout.
     setTimeout (->
       award.tooltip()
     ), 200
     
 
-  createEmoji: (emoji, custom_path) ->
+  createEmoji: (emoji) ->
+    emojiCssClass = @resolveNameToCssClass(emoji)
+
     nodes = []
     nodes.push("<div class='award active' title='me'>")
-    nodes.push("<div class='icon' data-emoji='" + emoji + "'>")
-    nodes.push(@getImage(emoji, custom_path))
+    nodes.push("<div class='icon emoji-icon #{emojiCssClass}' data-emoji='#{emoji}'></div>")
+    nodes.push("<div class='counter'>1</div>")
     nodes.push("</div>")
-    nodes.push("<div class='counter'>1")
-    nodes.push("</div></div>")
 
-    $(".awards-controls").before(nodes.join("\n"))
+    emoji_node = $(nodes.join("\n")).insertBefore(".awards-controls").find(".emoji-icon").data("emoji", emoji)
 
     $(".award").tooltip()
 
-  getImage: (emoji, custom_path) ->
-    if custom_path
-      $("<img>").attr({src: custom_path, width: 20, height: 20}).wrap("<div>").parent().html()
+  resolveNameToCssClass: (emoji) ->
+    emoji_icon = $(".emoji-menu-content [data-emoji='#{emoji}']")
+
+    if emoji_icon.length > 0
+      unicodeName = emoji_icon.data("unicode-name")
     else
-      $("li[data-emoji='" + emoji + "']").html()
+      # Find by alias
+      unicodeName = $(".emoji-menu-content [data-aliases*=':#{emoji}:']").data("unicode-name")
 
+    "emoji-#{unicodeName}"
 
   postEmoji: (emoji, callback) ->
     $.post @post_emoji_url, { note: {
-      note: ":" + emoji + ":"
+      note: ":#{emoji}:"
       noteable_type: @noteable_type
       noteable_id: @noteable_id
     }},(data) ->
@@ -90,7 +110,7 @@ class @AwardsHandler
         callback.call()
 
   findEmojiIcon: (emoji) ->
-    $(".icon[data-emoji='" + emoji + "']")
+    $(".award [data-emoji='#{emoji}']")
 
   scrollToAwards: ->
     $('body, html').animate({
@@ -99,3 +119,46 @@ class @AwardsHandler
 
   normilizeEmojiName: (emoji) ->
     @aliases[emoji] || emoji
+
+  addEmojiToFrequentlyUsedList: (emoji) ->
+    frequently_used_emojis = @getFrequentlyUsedEmojis()
+    frequently_used_emojis.push(emoji)
+    $.cookie('frequently_used_emojis', frequently_used_emojis.join(","), { expires: 365 })
+
+  getFrequentlyUsedEmojis: ->
+    frequently_used_emojis = ($.cookie('frequently_used_emojis') || "").split(",")
+
+    frequently_used_emojis = ["thumbsup", "thumbsdown"].concat(frequently_used_emojis)
+
+    _.compact(_.uniq(frequently_used_emojis))
+
+  renderFrequentlyUsedBlock: ->
+    frequently_used_emojis = @getFrequentlyUsedEmojis()
+
+    ul = $("<ul>")
+
+    for emoji in frequently_used_emojis
+      do (emoji) ->
+        $(".emoji-menu-content [data-emoji='#{emoji}']").closest("li").clone().appendTo(ul)
+
+    $("input.emoji-search").after(ul).after($("<h5>").text("Frequently used"))
+
+  setupSearch: ->
+    $("input.emoji-search").keyup (ev) =>
+      term = $(ev.target).val()
+
+      # Clean previous search results
+      $("ul.emoji-search,h5.emoji-search").remove()
+
+      if term
+        # Generate a search result block
+        h5 = $("<h5>").text("Search results").addClass("emoji-search")
+        found_emojis = @searchEmojis(term).show()
+        ul = $("<ul>").addClass("emoji-search").append(found_emojis)
+        $(".emoji-menu-content ul, .emoji-menu-content h5").hide()
+        $(".emoji-menu-content").append(h5).append(ul)
+      else
+        $(".emoji-menu-content").children().show()
+
+  searchEmojis: (term)->
+    $(".emoji-menu-content [data-emoji*='#{term}']").closest("li").clone()
diff --git a/app/assets/javascripts/blob/blob_file_dropzone.js.coffee b/app/assets/javascripts/blob/blob_file_dropzone.js.coffee
index 195f8b11e5dbac896379cd30d13f3caa3532e130..9df932817f6aa785360c5b0a973f3d3895369be7 100644
--- a/app/assets/javascripts/blob/blob_file_dropzone.js.coffee
+++ b/app/assets/javascripts/blob/blob_file_dropzone.js.coffee
@@ -35,7 +35,7 @@ class @BlobFileDropzone
           return
 
         this.on 'sending', (file, xhr, formData) ->
-          formData.append('new_branch', form.find('.js-new-branch').val())
+          formData.append('target_branch', form.find('.js-target-branch').val())
           formData.append('create_merge_request', form.find('.js-create-merge-request').val())
           formData.append('commit_message', form.find('.js-commit-message').val())
           return
diff --git a/app/assets/javascripts/merge_request_widget.js.coffee b/app/assets/javascripts/merge_request_widget.js.coffee
index c4b63966fe77e590ce114d5968fe94bafea36db5..738ffc8343bfd34437915c56f7148ec2cbc8f5cc 100644
--- a/app/assets/javascripts/merge_request_widget.js.coffee
+++ b/app/assets/javascripts/merge_request_widget.js.coffee
@@ -18,7 +18,7 @@ class @MergeRequestWidget
         if data.state == "merged"
           urlSuffix = if deleteSourceBranch then '?delete_source=true' else ''
 
-          window.location.href = window.location.href + urlSuffix
+          window.location.href = window.location.pathname + urlSuffix
         else if data.merge_error
           $('.mr-widget-body').html("<h4>" + data.merge_error + "</h4>")
         else
diff --git a/app/assets/javascripts/new_branch_form.js.coffee b/app/assets/javascripts/new_branch_form.js.coffee
new file mode 100644
index 0000000000000000000000000000000000000000..4b350854f7855d438dc3a06d6c5ce202c9ed91af
--- /dev/null
+++ b/app/assets/javascripts/new_branch_form.js.coffee
@@ -0,0 +1,78 @@
+class @NewBranchForm
+  constructor: (form, availableRefs) ->
+    @branchNameError = form.find('.js-branch-name-error')
+    @name = form.find('.js-branch-name')
+    @ref  = form.find('#ref')
+
+    @setupAvailableRefs(availableRefs)
+    @setupRestrictions()
+    @addBinding()
+    @init()
+
+  addBinding: ->
+    @name.on 'blur', @validate
+
+  init: ->
+    @name.trigger 'blur' if @name.val().length > 0
+
+  setupAvailableRefs: (availableRefs) ->
+    @ref.autocomplete
+      source: availableRefs,
+      minLength: 1
+
+  setupRestrictions: ->
+    startsWith = {
+      pattern: /^(\/|\.)/g,
+      prefix: "can't start with",
+      conjunction: "or"
+    }
+
+    endsWith = {
+      pattern: /(\/|\.|\.lock)$/g,
+      prefix: "can't end in",
+      conjunction: "or"
+    }
+
+    invalid = {
+      pattern: /(\s|~|\^|:|\?|\*|\[|\\|\.\.|@\{|\/{2,}){1}/g
+      prefix: "can't contain",
+      conjunction: ", "
+    }
+
+    single = {
+      pattern: /^@+$/g
+      prefix: "can't be",
+      conjunction: "or"
+    }
+
+    @restrictions = [startsWith, invalid, endsWith, single]
+
+  validate: =>
+    @branchNameError.empty()
+
+    unique = (values, value) ->
+      values.push(value) unless value in values
+      values
+
+    formatter = (values, restriction) ->
+      formatted = values.map (value) ->
+        switch
+          when /\s/.test value then 'spaces'
+          when /\/{2,}/g.test value then 'consecutive slashes'
+          else "'#{value}'"
+
+      "#{restriction.prefix} #{formatted.join(restriction.conjunction)}"
+
+    validator = (errors, restriction) =>
+      matched = @name.val().match(restriction.pattern)
+
+      if matched
+        errors.concat formatter(matched.reduce(unique, []), restriction)
+      else
+        errors
+
+    errors = @restrictions.reduce validator, []
+
+    if errors.length > 0
+      errorMessage = $("<span/>").text(errors.join(', '))
+      @branchNameError.append(errorMessage)
diff --git a/app/assets/javascripts/new_commit_form.js.coffee b/app/assets/javascripts/new_commit_form.js.coffee
index 3c7b776155fb2929da92df64237075e0bff6bc52..03f0f51acfad536ba0927ceaf5541f774796e0dd 100644
--- a/app/assets/javascripts/new_commit_form.js.coffee
+++ b/app/assets/javascripts/new_commit_form.js.coffee
@@ -1,6 +1,6 @@
 class @NewCommitForm
   constructor: (form) ->
-    @newBranch = form.find('.js-new-branch')
+    @newBranch = form.find('.js-target-branch')
     @originalBranch = form.find('.js-original-branch')
     @createMergeRequest = form.find('.js-create-merge-request')
     @createMergeRequestContainer = form.find('.js-create-merge-request-container')
diff --git a/app/assets/javascripts/notes.js.coffee b/app/assets/javascripts/notes.js.coffee
index 35dc7829da2d95571c8a7b41797709115a206f25..9e5204bfeebb7b474ad935e64a3eb59e46d2daa2 100644
--- a/app/assets/javascripts/notes.js.coffee
+++ b/app/assets/javascripts/notes.js.coffee
@@ -127,7 +127,7 @@ class @Notes
       @initTaskList()
 
     if note.award
-      awards_handler.addAwardToEmojiBar(note.note, note.emoji_path)
+      awards_handler.addAwardToEmojiBar(note.note)
       awards_handler.scrollToAwards()
 
   ###
diff --git a/app/assets/javascripts/project.js.coffee b/app/assets/javascripts/project.js.coffee
index 1f221945c062668955f838add7ab4c034933c681..d7a658f8faa4dd0ce23db69fef1de40d01ec137b 100644
--- a/app/assets/javascripts/project.js.coffee
+++ b/app/assets/javascripts/project.js.coffee
@@ -1,7 +1,7 @@
 class @Project
   constructor: ->
     # Git protocol switcher
-    $('.js-protocol-switch').click ->
+    $('ul.clone-options-dropdown a').click ->
       return if $(@).hasClass('active')
 
 
@@ -10,7 +10,8 @@ class @Project
       # Add the active class for the clicked button
       $(@).toggleClass('active')
 
-      url = $(@).data('clone')
+      url = $("#project_clone").val()
+      console.log("url",url)
 
       # Update the input field
       $('#project_clone').val(url)
diff --git a/app/assets/javascripts/projects_list.js.coffee b/app/assets/javascripts/projects_list.js.coffee
index db5faf71faf79461144bdd260d9bb3adbf380c0b..f2887af190bc5a9e4093786822c0e51138a881e1 100644
--- a/app/assets/javascripts/projects_list.js.coffee
+++ b/app/assets/javascripts/projects_list.js.coffee
@@ -8,17 +8,17 @@ class @ProjectsList
 
     $(".projects-list-filter").keyup ->
       terms = $(this).val()
-      uiBox = $(this).closest('.projects-list-holder')
+      uiBox = $('div.projects-list-holder')
       if terms == "" || terms == undefined
-        uiBox.find(".projects-list li").show()
+        uiBox.find("ul.projects-list li").show()
       else
-        uiBox.find(".projects-list li").each (index) ->
-          name = $(this).find(".filter-title").text()
+        uiBox.find("ul.projects-list li").each (index) ->
+          name = $(this).find("span.filter-title").text()
 
           if name.toLowerCase().search(terms.toLowerCase()) == -1
             $(this).hide()
           else
             $(this).show()
-      uiBox.find(".projects-list li.bottom").hide()
+      uiBox.find("ul.projects-list li.bottom").hide()
 
 
diff --git a/app/assets/javascripts/star.js.coffee b/app/assets/javascripts/star.js.coffee
new file mode 100644
index 0000000000000000000000000000000000000000..d849b2e79500adbf730f3bee7a2ab1fb0ec18527
--- /dev/null
+++ b/app/assets/javascripts/star.js.coffee
@@ -0,0 +1,22 @@
+class @Star
+  constructor: ->
+    $('.project-home-panel .toggle-star').on('ajax:success', (e, data, status, xhr) ->
+      $this = $(this)
+      $starSpan = $this.find('span')
+      $starIcon = $this.find('i')
+
+      toggleStar = (isStarred) ->
+        $this.parent().find('span.count').text data.star_count
+        if isStarred
+          $starSpan.removeClass('starred').text 'Star'
+          $starIcon.removeClass('fa-star').addClass 'fa-star-o'
+        else
+          $starSpan.addClass('starred').text 'Unstar'
+          $starIcon.removeClass('fa-star-o').addClass 'fa-star'
+        return
+
+      toggleStar $starSpan.hasClass('starred')
+      return
+    ).on 'ajax:error', (e, xhr, status, error) ->
+      new Flash('Star toggle failed. Try again later.', 'alert')
+      return
\ No newline at end of file
diff --git a/app/assets/stylesheets/application.scss b/app/assets/stylesheets/application.scss
index 7b060ce48532c36dadd52950c5f8f293a7515821..0c0451fe4ddffcca924242dc13424067609af4a0 100644
--- a/app/assets/stylesheets/application.scss
+++ b/app/assets/stylesheets/application.scss
@@ -2,8 +2,8 @@
  * This is a manifest file that'll automatically include all the stylesheets available in this directory
  * and any sub-directories. You're free to add application-wide styles to this file and they'll appear at
  * the top of the compiled file, but it's generally better to create a new file per style scope.
- *= require jquery.ui.datepicker
- *= require jquery.ui.autocomplete
+ *= require jquery-ui/datepicker
+ *= require jquery-ui/autocomplete
  *= require jquery.atwho
  *= require select2
  *= require_self
@@ -48,4 +48,4 @@
 /*
  * Styles for JS behaviors.
  */
-@import "behaviors.scss";
\ No newline at end of file
+@import "behaviors.scss";
diff --git a/app/assets/stylesheets/framework/blocks.scss b/app/assets/stylesheets/framework/blocks.scss
index a62c0f62a4c862cd950accfcf367e17ecc5dfc4c..206d39cc9b3b198f42f82729eb5b1aca18062876 100644
--- a/app/assets/stylesheets/framework/blocks.scss
+++ b/app/assets/stylesheets/framework/blocks.scss
@@ -76,7 +76,7 @@
 
 .cover-block {
   text-align: center;
-  background: #f7f8fa;
+  background: $background-color;
   margin: -$gl-padding;
   margin-bottom: 0;
   padding: 44px $gl-padding;
diff --git a/app/assets/stylesheets/framework/buttons.scss b/app/assets/stylesheets/framework/buttons.scss
index fe56266284b9d5c5709ce5d2cdd0f2d00eb6226e..97a94638847576c5b8695581e3dd83f21c781865 100644
--- a/app/assets/stylesheets/framework/buttons.scss
+++ b/app/assets/stylesheets/framework/buttons.scss
@@ -1,10 +1,9 @@
 @mixin btn-default {
-  @include border-radius(2px);
+  @include border-radius(3px);
   border-width: 1px;
   border-style: solid;
-  text-transform: uppercase;
-  font-size: 13px;
-  font-weight: 600;
+  font-size: 15px;
+  font-weight: 500;
   line-height: 18px;
   padding: 11px $gl-padding;
   letter-spacing: .4px;
@@ -18,7 +17,7 @@
 
 @mixin btn-middle {
   @include btn-default;
-  @include border-radius(2px);
+  @include border-radius(3px);
   padding: 11px 24px;
 }
 
@@ -51,6 +50,10 @@
   @include btn-color($blue-light, $border-blue-light, $blue-normal, $border-blue-normal, $blue-dark, $border-blue-dark, #FFFFFF);
 }
 
+@mixin btn-blue-medium {
+  @include btn-color($blue-medium-light, $border-blue-light, $blue-medium, $border-blue-normal, $blue-medium-dark, $border-blue-dark, #FFFFFF);
+}
+
 @mixin btn-orange {
   @include btn-color($orange-light, $border-orange-light, $orange-normal, $border-orange-normal, $orange-dark, $border-orange-dark, #FFFFFF);
 }
@@ -60,7 +63,7 @@
 }
 
 @mixin btn-gray {
-  @include btn-color($gray-light, $border-gray-light, $gray-normal, $border-gray-normal, $gray-dark, $border-gray-dark, #313236);
+  @include btn-color($gray-light, $border-gray-light, $gray-normal, $border-gray-light, $gray-dark, $border-gray-dark, #313236);
 }
 
 @mixin btn-white {
@@ -75,6 +78,10 @@
     padding: 5px 10px;
   }
 
+  &.btn-nr {
+    padding: 7px 10px;
+  }
+
   &.btn-xs {
     padding: 1px 5px;
   }
@@ -91,11 +98,15 @@
     @include btn-gray;
   }
 
-  &.btn-primary,
+  &.btn-primary {
+    @include btn-blue-medium;
+  }
+
   &.btn-info {
     @include btn-blue;
   }
 
+  &.btn-close,
   &.btn-warning {
     @include btn-orange;
   }
@@ -110,20 +121,8 @@
     float: right;
   }
 
-  &.btn-close {
-    color: $gl-danger;
-    border-color: $gl-danger;
-    &:hover {
-      color: #B94A48;
-    }
-  }
-
   &.btn-reopen {
-    color: $gl-success;
-    border-color: $gl-success;
-    &:hover {
-      color: #468847;
-    }
+    /* should be same as parent class for now */
   }
 
   &.btn-grouped {
diff --git a/app/assets/stylesheets/framework/common.scss b/app/assets/stylesheets/framework/common.scss
index 7562ef6d24b9ea77ff2f05c834833f6acd0267f0..11730000f85e32f06b75fe0c282f7c3e0e00d802 100644
--- a/app/assets/stylesheets/framework/common.scss
+++ b/app/assets/stylesheets/framework/common.scss
@@ -374,7 +374,7 @@ table {
   }
 }
 
-.center-top-menu {
+.center-top-menu, .left-top-menu {
   @include nav-menu;
   text-align: center;
   margin-top: 5px;
@@ -408,6 +408,11 @@ table {
   }
 }
 
+.left-top-menu {
+  text-align: left;
+  border-bottom: 1px solid #EEE;
+}
+
 .center-middle-menu {
   @include nav-menu;
   padding: 0;
diff --git a/app/assets/stylesheets/framework/issue_box.scss b/app/assets/stylesheets/framework/issue_box.scss
index fba67ba0b64a0a3e552a9e6ef05cea22214878ae..e93dbab0c423673007ae683e417780c04031c27f 100644
--- a/app/assets/stylesheets/framework/issue_box.scss
+++ b/app/assets/stylesheets/framework/issue_box.scss
@@ -5,7 +5,7 @@
  */
 
 .status-box {
-  @include border-radius(2px);
+  @include border-radius(3px);
 
   display: block;
   float: left;
@@ -25,7 +25,7 @@
   }
 
   &.status-box-open {
-    background-color: #019875;
+    background-color: $green-light;
     color: #FFF;
   }
 
diff --git a/app/assets/stylesheets/framework/layout.scss b/app/assets/stylesheets/framework/layout.scss
index aa5acb93cc52cb96882493e1300bfe3ba94128bc..a1a9990241d6964d96bda9f13e882c2c7ae9c66e 100644
--- a/app/assets/stylesheets/framework/layout.scss
+++ b/app/assets/stylesheets/framework/layout.scss
@@ -5,7 +5,7 @@ html {
 }
 
 body {
-  background-color: #EAEBEC !important;
+  background-color: #F3F3F3 !important;
 
   &.navless {
     background-color: white !important;
diff --git a/app/assets/stylesheets/framework/mixins.scss b/app/assets/stylesheets/framework/mixins.scss
index 11c48d26ab53a27e50564b4c261ce0224653e6b0..41fd890f14f8046b858b3e6f56fffb4dd16ba338 100644
--- a/app/assets/stylesheets/framework/mixins.scss
+++ b/app/assets/stylesheets/framework/mixins.scss
@@ -123,7 +123,6 @@
   padding: 0;
   margin: 0;
   list-style: none;
-  margin-top: 5px;
   height: 56px;
 
   li {
@@ -131,9 +130,9 @@
 
     a {
       padding: 14px;
-      font-size: 17px;
+      font-size: 15px;
       line-height: 28px;
-      color: #7f8fa4;
+      color: #959494;
       border-bottom: 2px solid transparent;
 
       &:hover, &:active, &:focus {
@@ -143,8 +142,8 @@
     }
 
     &.active a {
-      color: #4c4e54;
-      border-bottom: 2px solid #1cacfc;
+      color: #616060;
+      border-bottom: 2px solid #4688f1;
     }
 
     .badge {
diff --git a/app/assets/stylesheets/framework/mobile.scss b/app/assets/stylesheets/framework/mobile.scss
index 6f44c323732325d73eed22088c5ee1f8c43883b7..c00709fb6bb9a3bb1d7f07080ed77ff2502610a1 100644
--- a/app/assets/stylesheets/framework/mobile.scss
+++ b/app/assets/stylesheets/framework/mobile.scss
@@ -81,7 +81,7 @@
     display: none;
   }
 
-  .center-top-menu {
+  .center-top-menu, .left-top-menu {
     li a {
       font-size: 14px;
       padding: 19px 10px;
diff --git a/app/assets/stylesheets/framework/variables.scss b/app/assets/stylesheets/framework/variables.scss
index 2ef40a6e51738724399a45b592faf9a30c757152..af75123b0af367508648ead871ee196e231dc049 100644
--- a/app/assets/stylesheets/framework/variables.scss
+++ b/app/assets/stylesheets/framework/variables.scss
@@ -1,9 +1,9 @@
-$hover: #FFFAF1;
+$hover: #faf9f9;
 $gl-text-color: #54565B;
 $gl-text-green: #4A2;
 $gl-text-red: #D12F19;
 $gl-text-orange: #D90;
-$gl-header-color: #4c4e54;
+$gl-header-color: #323232;
 $gl-link-color: #333c48;
 $md-text-color: #444;
 $md-link-color: #3084bb;
@@ -15,13 +15,14 @@ $sidebar_width: 230px;
 $avatar_radius: 50%;
 $code_font_size: 13px;
 $code_line_height: 1.5;
-$border-color: #dce0e6;
+$border-color: #efeff1;
 $table-border-color: #eef0f2;
-$background-color: #F7F8FA;
+$background-color: #faf9f9;
 $header-height: 58px;
 $fixed-layout-width: 1280px;
-$gl-gray: #7f8fa4;
+$gl-gray: #5a5a5a;
 $gl-padding: 16px;
+$gl-padding-top:10px;
 $gl-avatar-size: 46px;
 
 /*
@@ -29,12 +30,12 @@ $gl-avatar-size: 46px;
  */
 
 $white-light: #FFFFFF;
-$white-normal: #DCE0E5;
-$white-dark: #E4E7ED;
+$white-normal: #ededed;
+$white-dark: #ededed;
 
-$gray-light: #F0F2F5;
-$gray-normal: #DCE0E5;
-$gray-dark: #E4E7ED;
+$gray-light: #f7f7f7;
+$gray-normal: #ededed;
+$gray-dark: #ededed;
 
 $green-light: #31AF64;
 $green-normal: #2FAA60;
@@ -44,6 +45,10 @@ $blue-light: #2EA8E5;
 $blue-normal: #2D9FD8;
 $blue-dark: #2897CE;
 
+$blue-medium-light: #3498CB;
+$blue-medium: #2F8EBF;
+$blue-medium-dark: #2D86B4;
+
 $orange-light: #FC6443;
 $orange-normal: #E75E40;
 $orange-dark: #CE5237;
@@ -52,11 +57,11 @@ $red-light: #F43263;
 $red-normal: #E52C5A;
 $red-dark: #D22852;
 
-$border-white-light: #E3E7EC;
+$border-white-light: #F1F2F4;
 $border-white-normal: #D6DAE2;
 $border-white-dark: #C6CACF;
 
-$border-gray-light: #DCE0E5;
+$border-gray-light: #d1d1d1;
 $border-gray-normal: #D6DAE2;
 $border-gray-dark: #C6CACF;
 
@@ -76,6 +81,8 @@ $border-red-light: #E52C5A;
 $border-red-normal: #D22852;
 $border-red-dark: #CA264F;
 
+/* header */
+$light-grey-header: #faf9f9;
 
 /*
  * State colors:
diff --git a/app/assets/stylesheets/pages/awards.scss b/app/assets/stylesheets/pages/awards.scss
index 041b811a606b6f418e6417cb3e27fd4c43c04135..87dd30f41114daf3ab6d6bad96e781b38aadcaab 100644
--- a/app/assets/stylesheets/pages/awards.scss
+++ b/app/assets/stylesheets/pages/awards.scss
@@ -2,6 +2,12 @@
   @include clearfix;
   line-height: 34px;
 
+  .emoji-icon {
+    width: 20px;
+    height: 20px;
+    margin: 7px 0 0 5px;
+  }
+
   .award {
     @include border-radius(5px);
 
@@ -40,6 +46,7 @@
   }
 
   .awards-controls {
+    position: relative;
     margin-left: 10px;
     float: left;
 
@@ -55,32 +62,64 @@
       }
     }
 
-    .awards-menu {
-      padding: $gl-padding;
-      min-width: 214px;
+    .emoji-menu{
+      position: absolute;
+      top: 100%;
+      left: 0;
+      z-index: 1000;
+      display: none;
+      float: left;
+      min-width: 160px;
+      padding: 5px 0;
+      margin: 2px 0 0;
+      font-size: 14px;
+      text-align: left;
+      list-style: none;
+      background-color: #fff;
+      -webkit-background-clip: padding-box;
+      background-clip: padding-box;
+      border: 1px solid #ccc;
+      border: 1px solid rgba(0,0,0,.15);
+      border-radius: 4px;
+      -webkit-box-shadow: 0 6px 12px rgba(0,0,0,.175);
+      box-shadow: 0 6px 12px rgba(0,0,0,.175);
+
+      .emoji-menu-content {
+        padding: $gl-padding;
+        width: 300px;
+        height: 300px;
+        overflow-y: scroll;
+
+        h5 {
+          clear: left;
+        }
 
-      > li {
-        cursor: pointer;
-        width: 30px;
-        height: 30px;
-        text-align: center;
-        @include border-radius(5px);
+        ul {
+          list-style-type: none;
+          margin-left: -20px;
+          margin-bottom: 20px;
+          overflow: auto;
+        }
 
-        img {
-          margin-bottom: 2px;
+        input.emoji-search{
+          background: image-url("icon-search.png") 240px no-repeat;
         }
 
-        &:hover {
-          background-color: #ccc;
+        li {
+          cursor: pointer;
+          width: 30px;
+          height: 30px;
+          text-align: center;
+          float: left;
+          margin: 3px;
+          list-decorate: none;
+          @include border-radius(5px);
+
+          &:hover {
+            background-color: #ccc;
+          }
         }
       }
     }
   }
-
-  .awards-menu{
-    li {
-      float: left;
-      margin: 3px;
-    }
-  }
 }
diff --git a/app/assets/stylesheets/pages/detail_page.scss b/app/assets/stylesheets/pages/detail_page.scss
index 0f3463a914474988f71ac010dedfbe37401e8508..deab805dbc2988ab003f6f5b47675e7cb1697a92 100644
--- a/app/assets/stylesheets/pages/detail_page.scss
+++ b/app/assets/stylesheets/pages/detail_page.scss
@@ -5,7 +5,7 @@
   border-bottom: 1px solid $border-color;
   color: #5c5d5e;
   font-size: 16px;
-  line-height: 42px;
+  line-height: 34px;
 
   .author {
     color: #5c5d5e;
diff --git a/app/assets/stylesheets/pages/emojis.scss b/app/assets/stylesheets/pages/emojis.scss
new file mode 100644
index 0000000000000000000000000000000000000000..89a94c5a780b5a7a552436475251d008370ada23
--- /dev/null
+++ b/app/assets/stylesheets/pages/emojis.scss
@@ -0,0 +1,1272 @@
+/*
+File is generated by https://github.com/jakesgordon/sprite-factory and midified manualy
+The source: gemojione gem.
+*/
+
+.emoji-icon{
+  background-image: image-url("emoji.png");
+  background-repeat: no-repeat;
+}
+
+.emoji-0023-20E3 { background-position: 0px 0px; }
+.emoji-0030-20E3 { background-position: -20px 0px; }
+.emoji-0031-20E3 { background-position: -40px 0px; }
+.emoji-0032-20E3 { background-position: -60px 0px; }
+.emoji-0033-20E3 { background-position: -80px 0px; }
+.emoji-0034-20E3 { background-position: -100px 0px; }
+.emoji-0035-20E3 { background-position: -120px 0px; }
+.emoji-0036-20E3 { background-position: -140px 0px; }
+.emoji-0037-20E3 { background-position: -160px 0px; }
+.emoji-0038-20E3 { background-position: -180px 0px; }
+.emoji-0039-20E3 { background-position: -200px 0px; }
+.emoji-00A9 { background-position: -220px 0px; }
+.emoji-00AE { background-position: -240px 0px; }
+.emoji-1F004 { background-position: -260px 0px; }
+.emoji-1F0CF { background-position: -280px 0px; }
+.emoji-1F170 { background-position: -300px 0px; }
+.emoji-1F171 { background-position: -320px 0px; }
+.emoji-1F17E { background-position: -340px 0px; }
+.emoji-1F17F { background-position: -360px 0px; }
+.emoji-1F18E { background-position: -380px 0px; }
+.emoji-1F191 { background-position: -400px 0px; }
+.emoji-1F192 { background-position: -420px 0px; }
+.emoji-1F193 { background-position: -440px 0px; }
+.emoji-1F194 { background-position: -460px 0px; }
+.emoji-1F195 { background-position: -480px 0px; }
+.emoji-1F196 { background-position: -500px 0px; }
+.emoji-1F197 { background-position: -520px 0px; }
+.emoji-1F198 { background-position: -540px 0px; }
+.emoji-1F199 { background-position: -560px 0px; }
+.emoji-1F19A { background-position: -580px 0px; }
+.emoji-1F1E6-1F1E8 { background-position: -600px 0px; }
+.emoji-1F1E6-1F1E9 { background-position: -620px 0px; }
+.emoji-1F1E6-1F1EA { background-position: -640px 0px; }
+.emoji-1F1E6-1F1EB { background-position: -660px 0px; }
+.emoji-1F1E6-1F1EC { background-position: -680px 0px; }
+.emoji-1F1E6-1F1EE { background-position: -700px 0px; }
+.emoji-1F1E6-1F1F1 { background-position: -720px 0px; }
+.emoji-1F1E6-1F1F2 { background-position: -740px 0px; }
+.emoji-1F1E6-1F1F4 { background-position: -760px 0px; }
+.emoji-1F1E6-1F1F7 { background-position: -780px 0px; }
+.emoji-1F1E6-1F1F9 { background-position: -800px 0px; }
+.emoji-1F1E6-1F1FA { background-position: -820px 0px; }
+.emoji-1F1E6-1F1FC { background-position: -840px 0px; }
+.emoji-1F1E6-1F1FF { background-position: -860px 0px; }
+.emoji-1F1E7-1F1E6 { background-position: -880px 0px; }
+.emoji-1F1E7-1F1E7 { background-position: -900px 0px; }
+.emoji-1F1E7-1F1E9 { background-position: -920px 0px; }
+.emoji-1F1E7-1F1EA { background-position: -940px 0px; }
+.emoji-1F1E7-1F1EB { background-position: -960px 0px; }
+.emoji-1F1E7-1F1EC { background-position: -980px 0px; }
+.emoji-1F1E7-1F1ED { background-position: -1000px 0px; }
+.emoji-1F1E7-1F1EE { background-position: -1020px 0px; }
+.emoji-1F1E7-1F1EF { background-position: -1040px 0px; }
+.emoji-1F1E7-1F1F2 { background-position: -1060px 0px; }
+.emoji-1F1E7-1F1F3 { background-position: -1080px 0px; }
+.emoji-1F1E7-1F1F4 { background-position: -1100px 0px; }
+.emoji-1F1E7-1F1F7 { background-position: -1120px 0px; }
+.emoji-1F1E7-1F1F8 { background-position: -1140px 0px; }
+.emoji-1F1E7-1F1F9 { background-position: -1160px 0px; }
+.emoji-1F1E7-1F1FC { background-position: -1180px 0px; }
+.emoji-1F1E7-1F1FE { background-position: -1200px 0px; }
+.emoji-1F1E7-1F1FF { background-position: -1220px 0px; }
+.emoji-1F1E8-1F1E6 { background-position: -1240px 0px; }
+.emoji-1F1E8-1F1E9 { background-position: -1260px 0px; }
+.emoji-1F1E8-1F1EB { background-position: -1280px 0px; }
+.emoji-1F1E8-1F1EC { background-position: -1300px 0px; }
+.emoji-1F1E8-1F1ED { background-position: -1320px 0px; }
+.emoji-1F1E8-1F1EE { background-position: -1340px 0px; }
+.emoji-1F1E8-1F1F1 { background-position: -1360px 0px; }
+.emoji-1F1E8-1F1F2 { background-position: -1380px 0px; }
+.emoji-1F1E8-1F1F3 { background-position: -1400px 0px; }
+.emoji-1F1E8-1F1F4 { background-position: -1420px 0px; }
+.emoji-1F1E8-1F1F7 { background-position: -1440px 0px; }
+.emoji-1F1E8-1F1FA { background-position: -1460px 0px; }
+.emoji-1F1E8-1F1FB { background-position: -1480px 0px; }
+.emoji-1F1E8-1F1FE { background-position: -1500px 0px; }
+.emoji-1F1E8-1F1FF { background-position: -1520px 0px; }
+.emoji-1F1E9-1F1EA { background-position: -1540px 0px; }
+.emoji-1F1E9-1F1EF { background-position: -1560px 0px; }
+.emoji-1F1E9-1F1F0 { background-position: -1580px 0px; }
+.emoji-1F1E9-1F1F2 { background-position: -1600px 0px; }
+.emoji-1F1E9-1F1F4 { background-position: -1620px 0px; }
+.emoji-1F1E9-1F1FF { background-position: -1640px 0px; }
+.emoji-1F1EA-1F1E8 { background-position: -1660px 0px; }
+.emoji-1F1EA-1F1EA { background-position: -1680px 0px; }
+.emoji-1F1EA-1F1EC { background-position: -1700px 0px; }
+.emoji-1F1EA-1F1ED { background-position: -1720px 0px; }
+.emoji-1F1EA-1F1F7 { background-position: -1740px 0px; }
+.emoji-1F1EA-1F1F8 { background-position: -1760px 0px; }
+.emoji-1F1EA-1F1F9 { background-position: -1780px 0px; }
+.emoji-1F1EB-1F1EE { background-position: -1800px 0px; }
+.emoji-1F1EB-1F1EF { background-position: -1820px 0px; }
+.emoji-1F1EB-1F1F0 { background-position: -1840px 0px; }
+.emoji-1F1EB-1F1F2 { background-position: -1860px 0px; }
+.emoji-1F1EB-1F1F4 { background-position: -1880px 0px; }
+.emoji-1F1EB-1F1F7 { background-position: -1900px 0px; }
+.emoji-1F1EC-1F1E6 { background-position: -1920px 0px; }
+.emoji-1F1EC-1F1E7 { background-position: -1940px 0px; }
+.emoji-1F1EC-1F1E9 { background-position: -1960px 0px; }
+.emoji-1F1EC-1F1EA { background-position: -1980px 0px; }
+.emoji-1F1EC-1F1ED { background-position: -2000px 0px; }
+.emoji-1F1EC-1F1EE { background-position: -2020px 0px; }
+.emoji-1F1EC-1F1F1 { background-position: -2040px 0px; }
+.emoji-1F1EC-1F1F2 { background-position: -2060px 0px; }
+.emoji-1F1EC-1F1F3 { background-position: -2080px 0px; }
+.emoji-1F1EC-1F1F6 { background-position: -2100px 0px; }
+.emoji-1F1EC-1F1F7 { background-position: -2120px 0px; }
+.emoji-1F1EC-1F1F9 { background-position: -2140px 0px; }
+.emoji-1F1EC-1F1FA { background-position: -2160px 0px; }
+.emoji-1F1EC-1F1FC { background-position: -2180px 0px; }
+.emoji-1F1EC-1F1FE { background-position: -2200px 0px; }
+.emoji-1F1ED-1F1F0 { background-position: -2220px 0px; }
+.emoji-1F1ED-1F1F3 { background-position: -2240px 0px; }
+.emoji-1F1ED-1F1F7 { background-position: -2260px 0px; }
+.emoji-1F1ED-1F1F9 { background-position: -2280px 0px; }
+.emoji-1F1ED-1F1FA { background-position: -2300px 0px; }
+.emoji-1F1EE-1F1E9 { background-position: -2320px 0px; }
+.emoji-1F1EE-1F1EA { background-position: -2340px 0px; }
+.emoji-1F1EE-1F1F1 { background-position: -2360px 0px; }
+.emoji-1F1EE-1F1F3 { background-position: -2380px 0px; }
+.emoji-1F1EE-1F1F6 { background-position: -2400px 0px; }
+.emoji-1F1EE-1F1F7 { background-position: -2420px 0px; }
+.emoji-1F1EE-1F1F8 { background-position: -2440px 0px; }
+.emoji-1F1EE-1F1F9 { background-position: -2460px 0px; }
+.emoji-1F1EF-1F1EA { background-position: -2480px 0px; }
+.emoji-1F1EF-1F1F2 { background-position: -2500px 0px; }
+.emoji-1F1EF-1F1F4 { background-position: -2520px 0px; }
+.emoji-1F1EF-1F1F5 { background-position: -2540px 0px; }
+.emoji-1F1F0-1F1EA { background-position: -2560px 0px; }
+.emoji-1F1F0-1F1EC { background-position: -2580px 0px; }
+.emoji-1F1F0-1F1ED { background-position: -2600px 0px; }
+.emoji-1F1F0-1F1EE { background-position: -2620px 0px; }
+.emoji-1F1F0-1F1F2 { background-position: -2640px 0px; }
+.emoji-1F1F0-1F1F3 { background-position: -2660px 0px; }
+.emoji-1F1F0-1F1F5 { background-position: -2680px 0px; }
+.emoji-1F1F0-1F1F7 { background-position: -2700px 0px; }
+.emoji-1F1F0-1F1FC { background-position: -2720px 0px; }
+.emoji-1F1F0-1F1FE { background-position: -2740px 0px; }
+.emoji-1F1F0-1F1FF { background-position: -2760px 0px; }
+.emoji-1F1F1-1F1E6 { background-position: -2780px 0px; }
+.emoji-1F1F1-1F1E7 { background-position: -2800px 0px; }
+.emoji-1F1F1-1F1E8 { background-position: -2820px 0px; }
+.emoji-1F1F1-1F1EE { background-position: -2840px 0px; }
+.emoji-1F1F1-1F1F0 { background-position: -2860px 0px; }
+.emoji-1F1F1-1F1F7 { background-position: -2880px 0px; }
+.emoji-1F1F1-1F1F8 { background-position: -2900px 0px; }
+.emoji-1F1F1-1F1F9 { background-position: -2920px 0px; }
+.emoji-1F1F1-1F1FA { background-position: -2940px 0px; }
+.emoji-1F1F1-1F1FB { background-position: -2960px 0px; }
+.emoji-1F1F1-1F1FE { background-position: -2980px 0px; }
+.emoji-1F1F2-1F1E6 { background-position: -3000px 0px; }
+.emoji-1F1F2-1F1E8 { background-position: -3020px 0px; }
+.emoji-1F1F2-1F1E9 { background-position: -3040px 0px; }
+.emoji-1F1F2-1F1EA { background-position: -3060px 0px; }
+.emoji-1F1F2-1F1EC { background-position: -3080px 0px; }
+.emoji-1F1F2-1F1ED { background-position: -3100px 0px; }
+.emoji-1F1F2-1F1F0 { background-position: -3120px 0px; }
+.emoji-1F1F2-1F1F1 { background-position: -3140px 0px; }
+.emoji-1F1F2-1F1F2 { background-position: -3160px 0px; }
+.emoji-1F1F2-1F1F3 { background-position: -3180px 0px; }
+.emoji-1F1F2-1F1F4 { background-position: -3200px 0px; }
+.emoji-1F1F2-1F1F7 { background-position: -3220px 0px; }
+.emoji-1F1F2-1F1F8 { background-position: -3240px 0px; }
+.emoji-1F1F2-1F1F9 { background-position: -3260px 0px; }
+.emoji-1F1F2-1F1FA { background-position: -3280px 0px; }
+.emoji-1F1F2-1F1FB { background-position: -3300px 0px; }
+.emoji-1F1F2-1F1FC { background-position: -3320px 0px; }
+.emoji-1F1F2-1F1FD { background-position: -3340px 0px; }
+.emoji-1F1F2-1F1FE { background-position: -3360px 0px; }
+.emoji-1F1F2-1F1FF { background-position: -3380px 0px; }
+.emoji-1F1F3-1F1E6 { background-position: -3400px 0px; }
+.emoji-1F1F3-1F1E8 { background-position: -3420px 0px; }
+.emoji-1F1F3-1F1EA { background-position: -3440px 0px; }
+.emoji-1F1F3-1F1EC { background-position: -3460px 0px; }
+.emoji-1F1F3-1F1EE { background-position: -3480px 0px; }
+.emoji-1F1F3-1F1F1 { background-position: -3500px 0px; }
+.emoji-1F1F3-1F1F4 { background-position: -3520px 0px; }
+.emoji-1F1F3-1F1F5 { background-position: -3540px 0px; }
+.emoji-1F1F3-1F1F7 { background-position: -3560px 0px; }
+.emoji-1F1F3-1F1FA { background-position: -3580px 0px; }
+.emoji-1F1F3-1F1FF { background-position: -3600px 0px; }
+.emoji-1F1F4-1F1F2 { background-position: -3620px 0px; }
+.emoji-1F1F5-1F1E6 { background-position: -3640px 0px; }
+.emoji-1F1F5-1F1EA { background-position: -3660px 0px; }
+.emoji-1F1F5-1F1EB { background-position: -3680px 0px; }
+.emoji-1F1F5-1F1EC { background-position: -3700px 0px; }
+.emoji-1F1F5-1F1ED { background-position: -3720px 0px; }
+.emoji-1F1F5-1F1F0 { background-position: -3740px 0px; }
+.emoji-1F1F5-1F1F1 { background-position: -3760px 0px; }
+.emoji-1F1F5-1F1F7 { background-position: -3780px 0px; }
+.emoji-1F1F5-1F1F8 { background-position: -3800px 0px; }
+.emoji-1F1F5-1F1F9 { background-position: -3820px 0px; }
+.emoji-1F1F5-1F1FC { background-position: -3840px 0px; }
+.emoji-1F1F5-1F1FE { background-position: -3860px 0px; }
+.emoji-1F1F6-1F1E6 { background-position: -3880px 0px; }
+.emoji-1F1F7-1F1F4 { background-position: -3900px 0px; }
+.emoji-1F1F7-1F1F8 { background-position: -3920px 0px; }
+.emoji-1F1F7-1F1FA { background-position: -3940px 0px; }
+.emoji-1F1F7-1F1FC { background-position: -3960px 0px; }
+.emoji-1F1F8-1F1E6 { background-position: -3980px 0px; }
+.emoji-1F1F8-1F1E7 { background-position: -4000px 0px; }
+.emoji-1F1F8-1F1E8 { background-position: -4020px 0px; }
+.emoji-1F1F8-1F1E9 { background-position: -4040px 0px; }
+.emoji-1F1F8-1F1EA { background-position: -4060px 0px; }
+.emoji-1F1F8-1F1EC { background-position: -4080px 0px; }
+.emoji-1F1F8-1F1ED { background-position: -4100px 0px; }
+.emoji-1F1F8-1F1EE { background-position: -4120px 0px; }
+.emoji-1F1F8-1F1F0 { background-position: -4140px 0px; }
+.emoji-1F1F8-1F1F1 { background-position: -4160px 0px; }
+.emoji-1F1F8-1F1F2 { background-position: -4180px 0px; }
+.emoji-1F1F8-1F1F3 { background-position: -4200px 0px; }
+.emoji-1F1F8-1F1F4 { background-position: -4220px 0px; }
+.emoji-1F1F8-1F1F7 { background-position: -4240px 0px; }
+.emoji-1F1F8-1F1F9 { background-position: -4260px 0px; }
+.emoji-1F1F8-1F1FB { background-position: -4280px 0px; }
+.emoji-1F1F8-1F1FE { background-position: -4300px 0px; }
+.emoji-1F1F8-1F1FF { background-position: -4320px 0px; }
+.emoji-1F1F9-1F1E9 { background-position: -4340px 0px; }
+.emoji-1F1F9-1F1EC { background-position: -4360px 0px; }
+.emoji-1F1F9-1F1ED { background-position: -4380px 0px; }
+.emoji-1F1F9-1F1EF { background-position: -4400px 0px; }
+.emoji-1F1F9-1F1F1 { background-position: -4420px 0px; }
+.emoji-1F1F9-1F1F2 { background-position: -4440px 0px; }
+.emoji-1F1F9-1F1F3 { background-position: -4460px 0px; }
+.emoji-1F1F9-1F1F4 { background-position: -4480px 0px; }
+.emoji-1F1F9-1F1F7 { background-position: -4500px 0px; }
+.emoji-1F1F9-1F1F9 { background-position: -4520px 0px; }
+.emoji-1F1F9-1F1FB { background-position: -4540px 0px; }
+.emoji-1F1F9-1F1FC { background-position: -4560px 0px; }
+.emoji-1F1F9-1F1FF { background-position: -4580px 0px; }
+.emoji-1F1FA-1F1E6 { background-position: -4600px 0px; }
+.emoji-1F1FA-1F1EC { background-position: -4620px 0px; }
+.emoji-1F1FA-1F1F8 { background-position: -4640px 0px; }
+.emoji-1F1FA-1F1FE { background-position: -4660px 0px; }
+.emoji-1F1FA-1F1FF { background-position: -4680px 0px; }
+.emoji-1F1FB-1F1E6 { background-position: -4700px 0px; }
+.emoji-1F1FB-1F1E8 { background-position: -4720px 0px; }
+.emoji-1F1FB-1F1EA { background-position: -4740px 0px; }
+.emoji-1F1FB-1F1EE { background-position: -4760px 0px; }
+.emoji-1F1FB-1F1F3 { background-position: -4780px 0px; }
+.emoji-1F1FB-1F1FA { background-position: -4800px 0px; }
+.emoji-1F1FC-1F1EB { background-position: -4820px 0px; }
+.emoji-1F1FC-1F1F8 { background-position: -4840px 0px; }
+.emoji-1F1FD-1F1F0 { background-position: -4860px 0px; }
+.emoji-1F1FE-1F1EA { background-position: -4880px 0px; }
+.emoji-1F1FF-1F1E6 { background-position: -4900px 0px; }
+.emoji-1F1FF-1F1F2 { background-position: -4920px 0px; }
+.emoji-1F1FF-1F1FC { background-position: -4940px 0px; }
+.emoji-1F201 { background-position: -4960px 0px; }
+.emoji-1F202 { background-position: -4980px 0px; }
+.emoji-1F21A { background-position: -5000px 0px; }
+.emoji-1F22F { background-position: -5020px 0px; }
+.emoji-1F232 { background-position: -5040px 0px; }
+.emoji-1F233 { background-position: -5060px 0px; }
+.emoji-1F234 { background-position: -5080px 0px; }
+.emoji-1F235 { background-position: -5100px 0px; }
+.emoji-1F236 { background-position: -5120px 0px; }
+.emoji-1F237 { background-position: -5140px 0px; }
+.emoji-1F238 { background-position: -5160px 0px; }
+.emoji-1F239 { background-position: -5180px 0px; }
+.emoji-1F23A { background-position: -5200px 0px; }
+.emoji-1F250 { background-position: -5220px 0px; }
+.emoji-1F251 { background-position: -5240px 0px; }
+.emoji-1F300 { background-position: -5260px 0px; }
+.emoji-1F301 { background-position: -5280px 0px; }
+.emoji-1F302 { background-position: -5300px 0px; }
+.emoji-1F303 { background-position: -5320px 0px; }
+.emoji-1F304 { background-position: -5340px 0px; }
+.emoji-1F305 { background-position: -5360px 0px; }
+.emoji-1F306 { background-position: -5380px 0px; }
+.emoji-1F307 { background-position: -5400px 0px; }
+.emoji-1F308 { background-position: -5420px 0px; }
+.emoji-1F309 { background-position: -5440px 0px; }
+.emoji-1F30A { background-position: -5460px 0px; }
+.emoji-1F30B { background-position: -5480px 0px; }
+.emoji-1F30C { background-position: -5500px 0px; }
+.emoji-1F30D { background-position: -5520px 0px; }
+.emoji-1F30E { background-position: -5540px 0px; }
+.emoji-1F30F { background-position: -5560px 0px; }
+.emoji-1F310 { background-position: -5580px 0px; }
+.emoji-1F311 { background-position: -5600px 0px; }
+.emoji-1F312 { background-position: -5620px 0px; }
+.emoji-1F313 { background-position: -5640px 0px; }
+.emoji-1F314 { background-position: -5660px 0px; }
+.emoji-1F315 { background-position: -5680px 0px; }
+.emoji-1F316 { background-position: -5700px 0px; }
+.emoji-1F317 { background-position: -5720px 0px; }
+.emoji-1F318 { background-position: -5740px 0px; }
+.emoji-1F319 { background-position: -5760px 0px; }
+.emoji-1F31A { background-position: -5780px 0px; }
+.emoji-1F31B { background-position: -5800px 0px; }
+.emoji-1F31C { background-position: -5820px 0px; }
+.emoji-1F31D { background-position: -5840px 0px; }
+.emoji-1F31E { background-position: -5860px 0px; }
+.emoji-1F31F { background-position: -5880px 0px; }
+.emoji-1F320 { background-position: -5900px 0px; }
+.emoji-1F321 { background-position: -5920px 0px; }
+.emoji-1F327 { background-position: -5940px 0px; }
+.emoji-1F328 { background-position: -5960px 0px; }
+.emoji-1F329 { background-position: -5980px 0px; }
+.emoji-1F32A { background-position: -6000px 0px; }
+.emoji-1F32B { background-position: -6020px 0px; }
+.emoji-1F32C { background-position: -6040px 0px; }
+.emoji-1F330 { background-position: -6060px 0px; }
+.emoji-1F331 { background-position: -6080px 0px; }
+.emoji-1F332 { background-position: -6100px 0px; }
+.emoji-1F333 { background-position: -6120px 0px; }
+.emoji-1F334 { background-position: -6140px 0px; }
+.emoji-1F335 { background-position: -6160px 0px; }
+.emoji-1F336 { background-position: -6180px 0px; }
+.emoji-1F337 { background-position: -6200px 0px; }
+.emoji-1F338 { background-position: -6220px 0px; }
+.emoji-1F339 { background-position: -6240px 0px; }
+.emoji-1F33A { background-position: -6260px 0px; }
+.emoji-1F33B { background-position: -6280px 0px; }
+.emoji-1F33C { background-position: -6300px 0px; }
+.emoji-1F33D { background-position: -6320px 0px; }
+.emoji-1F33E { background-position: -6340px 0px; }
+.emoji-1F33F { background-position: -6360px 0px; }
+.emoji-1F340 { background-position: -6380px 0px; }
+.emoji-1F341 { background-position: -6400px 0px; }
+.emoji-1F342 { background-position: -6420px 0px; }
+.emoji-1F343 { background-position: -6440px 0px; }
+.emoji-1F344 { background-position: -6460px 0px; }
+.emoji-1F345 { background-position: -6480px 0px; }
+.emoji-1F346 { background-position: -6500px 0px; }
+.emoji-1F347 { background-position: -6520px 0px; }
+.emoji-1F348 { background-position: -6540px 0px; }
+.emoji-1F349 { background-position: -6560px 0px; }
+.emoji-1F34A { background-position: -6580px 0px; }
+.emoji-1F34B { background-position: -6600px 0px; }
+.emoji-1F34C { background-position: -6620px 0px; }
+.emoji-1F34D { background-position: -6640px 0px; }
+.emoji-1F34E { background-position: -6660px 0px; }
+.emoji-1F34F { background-position: -6680px 0px; }
+.emoji-1F350 { background-position: -6700px 0px; }
+.emoji-1F351 { background-position: -6720px 0px; }
+.emoji-1F352 { background-position: -6740px 0px; }
+.emoji-1F353 { background-position: -6760px 0px; }
+.emoji-1F354 { background-position: -6780px 0px; }
+.emoji-1F355 { background-position: -6800px 0px; }
+.emoji-1F356 { background-position: -6820px 0px; }
+.emoji-1F357 { background-position: -6840px 0px; }
+.emoji-1F358 { background-position: -6860px 0px; }
+.emoji-1F359 { background-position: -6880px 0px; }
+.emoji-1F35A { background-position: -6900px 0px; }
+.emoji-1F35B { background-position: -6920px 0px; }
+.emoji-1F35C { background-position: -6940px 0px; }
+.emoji-1F35D { background-position: -6960px 0px; }
+.emoji-1F35E { background-position: -6980px 0px; }
+.emoji-1F35F { background-position: -7000px 0px; }
+.emoji-1F360 { background-position: -7020px 0px; }
+.emoji-1F361 { background-position: -7040px 0px; }
+.emoji-1F362 { background-position: -7060px 0px; }
+.emoji-1F363 { background-position: -7080px 0px; }
+.emoji-1F364 { background-position: -7100px 0px; }
+.emoji-1F365 { background-position: -7120px 0px; }
+.emoji-1F366 { background-position: -7140px 0px; }
+.emoji-1F367 { background-position: -7160px 0px; }
+.emoji-1F368 { background-position: -7180px 0px; }
+.emoji-1F369 { background-position: -7200px 0px; }
+.emoji-1F36A { background-position: -7220px 0px; }
+.emoji-1F36B { background-position: -7240px 0px; }
+.emoji-1F36C { background-position: -7260px 0px; }
+.emoji-1F36D { background-position: -7280px 0px; }
+.emoji-1F36E { background-position: -7300px 0px; }
+.emoji-1F36F { background-position: -7320px 0px; }
+.emoji-1F370 { background-position: -7340px 0px; }
+.emoji-1F371 { background-position: -7360px 0px; }
+.emoji-1F372 { background-position: -7380px 0px; }
+.emoji-1F373 { background-position: -7400px 0px; }
+.emoji-1F374 { background-position: -7420px 0px; }
+.emoji-1F375 { background-position: -7440px 0px; }
+.emoji-1F376 { background-position: -7460px 0px; }
+.emoji-1F377 { background-position: -7480px 0px; }
+.emoji-1F378 { background-position: -7500px 0px; }
+.emoji-1F379 { background-position: -7520px 0px; }
+.emoji-1F37A { background-position: -7540px 0px; }
+.emoji-1F37B { background-position: -7560px 0px; }
+.emoji-1F37C { background-position: -7580px 0px; }
+.emoji-1F37D { background-position: -7600px 0px; }
+.emoji-1F380 { background-position: -7620px 0px; }
+.emoji-1F381 { background-position: -7640px 0px; }
+.emoji-1F382 { background-position: -7660px 0px; }
+.emoji-1F383 { background-position: -7680px 0px; }
+.emoji-1F384 { background-position: -7700px 0px; }
+.emoji-1F385 { background-position: -7720px 0px; }
+.emoji-1F386 { background-position: -7740px 0px; }
+.emoji-1F387 { background-position: -7760px 0px; }
+.emoji-1F388 { background-position: -7780px 0px; }
+.emoji-1F389 { background-position: -7800px 0px; }
+.emoji-1F38A { background-position: -7820px 0px; }
+.emoji-1F38B { background-position: -7840px 0px; }
+.emoji-1F38C { background-position: -7860px 0px; }
+.emoji-1F38D { background-position: -7880px 0px; }
+.emoji-1F38E { background-position: -7900px 0px; }
+.emoji-1F38F { background-position: -7920px 0px; }
+.emoji-1F390 { background-position: -7940px 0px; }
+.emoji-1F391 { background-position: -7960px 0px; }
+.emoji-1F392 { background-position: -7980px 0px; }
+.emoji-1F393 { background-position: -8000px 0px; }
+.emoji-1F394 { background-position: -8020px 0px; }
+.emoji-1F395 { background-position: -8040px 0px; }
+.emoji-1F396 { background-position: -8060px 0px; }
+.emoji-1F397 { background-position: -8080px 0px; }
+.emoji-1F398 { background-position: -8100px 0px; }
+.emoji-1F399 { background-position: -8120px 0px; }
+.emoji-1F39A { background-position: -8140px 0px; }
+.emoji-1F39B { background-position: -8160px 0px; }
+.emoji-1F39C { background-position: -8180px 0px; }
+.emoji-1F39D { background-position: -8200px 0px; }
+.emoji-1F39E { background-position: -8220px 0px; }
+.emoji-1F39F { background-position: -8240px 0px; }
+.emoji-1F3A0 { background-position: -8260px 0px; }
+.emoji-1F3A1 { background-position: -8280px 0px; }
+.emoji-1F3A2 { background-position: -8300px 0px; }
+.emoji-1F3A3 { background-position: -8320px 0px; }
+.emoji-1F3A4 { background-position: -8340px 0px; }
+.emoji-1F3A5 { background-position: -8360px 0px; }
+.emoji-1F3A6 { background-position: -8380px 0px; }
+.emoji-1F3A7 { background-position: -8400px 0px; }
+.emoji-1F3A8 { background-position: -8420px 0px; }
+.emoji-1F3A9 { background-position: -8440px 0px; }
+.emoji-1F3AA { background-position: -8460px 0px; }
+.emoji-1F3AB { background-position: -8480px 0px; }
+.emoji-1F3AC { background-position: -8500px 0px; }
+.emoji-1F3AD { background-position: -8520px 0px; }
+.emoji-1F3AE { background-position: -8540px 0px; }
+.emoji-1F3AF { background-position: -8560px 0px; }
+.emoji-1F3B0 { background-position: -8580px 0px; }
+.emoji-1F3B1 { background-position: -8600px 0px; }
+.emoji-1F3B2 { background-position: -8620px 0px; }
+.emoji-1F3B3 { background-position: -8640px 0px; }
+.emoji-1F3B4 { background-position: -8660px 0px; }
+.emoji-1F3B5 { background-position: -8680px 0px; }
+.emoji-1F3B6 { background-position: -8700px 0px; }
+.emoji-1F3B7 { background-position: -8720px 0px; }
+.emoji-1F3B8 { background-position: -8740px 0px; }
+.emoji-1F3B9 { background-position: -8760px 0px; }
+.emoji-1F3BA { background-position: -8780px 0px; }
+.emoji-1F3BB { background-position: -8800px 0px; }
+.emoji-1F3BC { background-position: -8820px 0px; }
+.emoji-1F3BD { background-position: -8840px 0px; }
+.emoji-1F3BE { background-position: -8860px 0px; }
+.emoji-1F3BF { background-position: -8880px 0px; }
+.emoji-1F3C0 { background-position: -8900px 0px; }
+.emoji-1F3C1 { background-position: -8920px 0px; }
+.emoji-1F3C2 { background-position: -8940px 0px; }
+.emoji-1F3C3 { background-position: -8960px 0px; }
+.emoji-1F3C4 { background-position: -8980px 0px; }
+.emoji-1F3C5 { background-position: -9000px 0px; }
+.emoji-1F3C6 { background-position: -9020px 0px; }
+.emoji-1F3C7 { background-position: -9040px 0px; }
+.emoji-1F3C8 { background-position: -9060px 0px; }
+.emoji-1F3C9 { background-position: -9080px 0px; }
+.emoji-1F3CA { background-position: -9100px 0px; }
+.emoji-1F3CB { background-position: -9120px 0px; }
+.emoji-1F3CC { background-position: -9140px 0px; }
+.emoji-1F3CD { background-position: -9160px 0px; }
+.emoji-1F3CE { background-position: -9180px 0px; }
+.emoji-1F3D4 { background-position: -9200px 0px; }
+.emoji-1F3D5 { background-position: -9220px 0px; }
+.emoji-1F3D6 { background-position: -9240px 0px; }
+.emoji-1F3D7 { background-position: -9260px 0px; }
+.emoji-1F3D8 { background-position: -9280px 0px; }
+.emoji-1F3D9 { background-position: -9300px 0px; }
+.emoji-1F3DA { background-position: -9320px 0px; }
+.emoji-1F3DB { background-position: -9340px 0px; }
+.emoji-1F3DC { background-position: -9360px 0px; }
+.emoji-1F3DD { background-position: -9380px 0px; }
+.emoji-1F3DE { background-position: -9400px 0px; }
+.emoji-1F3DF { background-position: -9420px 0px; }
+.emoji-1F3E0 { background-position: -9440px 0px; }
+.emoji-1F3E1 { background-position: -9460px 0px; }
+.emoji-1F3E2 { background-position: -9480px 0px; }
+.emoji-1F3E3 { background-position: -9500px 0px; }
+.emoji-1F3E4 { background-position: -9520px 0px; }
+.emoji-1F3E5 { background-position: -9540px 0px; }
+.emoji-1F3E6 { background-position: -9560px 0px; }
+.emoji-1F3E7 { background-position: -9580px 0px; }
+.emoji-1F3E8 { background-position: -9600px 0px; }
+.emoji-1F3E9 { background-position: -9620px 0px; }
+.emoji-1F3EA { background-position: -9640px 0px; }
+.emoji-1F3EB { background-position: -9660px 0px; }
+.emoji-1F3EC { background-position: -9680px 0px; }
+.emoji-1F3ED { background-position: -9700px 0px; }
+.emoji-1F3EE { background-position: -9720px 0px; }
+.emoji-1F3EF { background-position: -9740px 0px; }
+.emoji-1F3F0 { background-position: -9760px 0px; }
+.emoji-1F3F1 { background-position: -9780px 0px; }
+.emoji-1F3F2 { background-position: -9800px 0px; }
+.emoji-1F3F3 { background-position: -9820px 0px; }
+.emoji-1F3F4 { background-position: -9840px 0px; }
+.emoji-1F3F5 { background-position: -9860px 0px; }
+.emoji-1F3F6 { background-position: -9880px 0px; }
+.emoji-1F3F7 { background-position: -9900px 0px; }
+.emoji-1F400 { background-position: -9920px 0px; }
+.emoji-1F401 { background-position: -9940px 0px; }
+.emoji-1F402 { background-position: -9960px 0px; }
+.emoji-1F403 { background-position: -9980px 0px; }
+.emoji-1F404 { background-position: -10000px 0px; }
+.emoji-1F405 { background-position: -10020px 0px; }
+.emoji-1F406 { background-position: -10040px 0px; }
+.emoji-1F407 { background-position: -10060px 0px; }
+.emoji-1F408 { background-position: -10080px 0px; }
+.emoji-1F409 { background-position: -10100px 0px; }
+.emoji-1F40A { background-position: -10120px 0px; }
+.emoji-1F40B { background-position: -10140px 0px; }
+.emoji-1F40C { background-position: -10160px 0px; }
+.emoji-1F40D { background-position: -10180px 0px; }
+.emoji-1F40E { background-position: -10200px 0px; }
+.emoji-1F40F { background-position: -10220px 0px; }
+.emoji-1F410 { background-position: -10240px 0px; }
+.emoji-1F411 { background-position: -10260px 0px; }
+.emoji-1F412 { background-position: -10280px 0px; }
+.emoji-1F413 { background-position: -10300px 0px; }
+.emoji-1F414 { background-position: -10320px 0px; }
+.emoji-1F415 { background-position: -10340px 0px; }
+.emoji-1F416 { background-position: -10360px 0px; }
+.emoji-1F417 { background-position: -10380px 0px; }
+.emoji-1F418 { background-position: -10400px 0px; }
+.emoji-1F419 { background-position: -10420px 0px; }
+.emoji-1F41A { background-position: -10440px 0px; }
+.emoji-1F41B { background-position: -10460px 0px; }
+.emoji-1F41C { background-position: -10480px 0px; }
+.emoji-1F41D { background-position: -10500px 0px; }
+.emoji-1F41E { background-position: -10520px 0px; }
+.emoji-1F41F { background-position: -10540px 0px; }
+.emoji-1F420 { background-position: -10560px 0px; }
+.emoji-1F421 { background-position: -10580px 0px; }
+.emoji-1F422 { background-position: -10600px 0px; }
+.emoji-1F423 { background-position: -10620px 0px; }
+.emoji-1F424 { background-position: -10640px 0px; }
+.emoji-1F425 { background-position: -10660px 0px; }
+.emoji-1F426 { background-position: -10680px 0px; }
+.emoji-1F427 { background-position: -10700px 0px; }
+.emoji-1F428 { background-position: -10720px 0px; }
+.emoji-1F429 { background-position: -10740px 0px; }
+.emoji-1F42A { background-position: -10760px 0px; }
+.emoji-1F42B { background-position: -10780px 0px; }
+.emoji-1F42C { background-position: -10800px 0px; }
+.emoji-1F42D { background-position: -10820px 0px; }
+.emoji-1F42E { background-position: -10840px 0px; }
+.emoji-1F42F { background-position: -10860px 0px; }
+.emoji-1F430 { background-position: -10880px 0px; }
+.emoji-1F431 { background-position: -10900px 0px; }
+.emoji-1F432 { background-position: -10920px 0px; }
+.emoji-1F433 { background-position: -10940px 0px; }
+.emoji-1F434 { background-position: -10960px 0px; }
+.emoji-1F435 { background-position: -10980px 0px; }
+.emoji-1F436 { background-position: -11000px 0px; }
+.emoji-1F437 { background-position: -11020px 0px; }
+.emoji-1F438 { background-position: -11040px 0px; }
+.emoji-1F439 { background-position: -11060px 0px; }
+.emoji-1F43A { background-position: -11080px 0px; }
+.emoji-1F43B { background-position: -11100px 0px; }
+.emoji-1F43C { background-position: -11120px 0px; }
+.emoji-1F43D { background-position: -11140px 0px; }
+.emoji-1F43E { background-position: -11160px 0px; }
+.emoji-1F43F { background-position: -11180px 0px; }
+.emoji-1F440 { background-position: -11200px 0px; }
+.emoji-1F441 { background-position: -11220px 0px; }
+.emoji-1F442 { background-position: -11240px 0px; }
+.emoji-1F443 { background-position: -11260px 0px; }
+.emoji-1F444 { background-position: -11280px 0px; }
+.emoji-1F445 { background-position: -11300px 0px; }
+.emoji-1F446 { background-position: -11320px 0px; }
+.emoji-1F447 { background-position: -11340px 0px; }
+.emoji-1F448 { background-position: -11360px 0px; }
+.emoji-1F449 { background-position: -11380px 0px; }
+.emoji-1F44A { background-position: -11400px 0px; }
+.emoji-1F44B { background-position: -11420px 0px; }
+.emoji-1F44C { background-position: -11440px 0px; }
+.emoji-1F44D { background-position: -11460px 0px; }
+.emoji-1F44E { background-position: -11480px 0px; }
+.emoji-1F44F { background-position: -11500px 0px; }
+.emoji-1F450 { background-position: -11520px 0px; }
+.emoji-1F451 { background-position: -11540px 0px; }
+.emoji-1F452 { background-position: -11560px 0px; }
+.emoji-1F453 { background-position: -11580px 0px; }
+.emoji-1F454 { background-position: -11600px 0px; }
+.emoji-1F455 { background-position: -11620px 0px; }
+.emoji-1F456 { background-position: -11640px 0px; }
+.emoji-1F457 { background-position: -11660px 0px; }
+.emoji-1F458 { background-position: -11680px 0px; }
+.emoji-1F459 { background-position: -11700px 0px; }
+.emoji-1F45A { background-position: -11720px 0px; }
+.emoji-1F45B { background-position: -11740px 0px; }
+.emoji-1F45C { background-position: -11760px 0px; }
+.emoji-1F45D { background-position: -11780px 0px; }
+.emoji-1F45E { background-position: -11800px 0px; }
+.emoji-1F45F { background-position: -11820px 0px; }
+.emoji-1F460 { background-position: -11840px 0px; }
+.emoji-1F461 { background-position: -11860px 0px; }
+.emoji-1F462 { background-position: -11880px 0px; }
+.emoji-1F463 { background-position: -11900px 0px; }
+.emoji-1F464 { background-position: -11920px 0px; }
+.emoji-1F465 { background-position: -11940px 0px; }
+.emoji-1F466 { background-position: -11960px 0px; }
+.emoji-1F467 { background-position: -11980px 0px; }
+.emoji-1F468 { background-position: -12000px 0px; }
+.emoji-1F468-1F468-1F466 { background-position: -12020px 0px; }
+.emoji-1F468-1F468-1F466-1F466 { background-position: -12040px 0px; }
+.emoji-1F468-1F468-1F467 { background-position: -12060px 0px; }
+.emoji-1F468-1F468-1F467-1F466 { background-position: -12080px 0px; }
+.emoji-1F468-1F468-1F467-1F467 { background-position: -12100px 0px; }
+.emoji-1F468-1F469-1F466-1F466 { background-position: -12120px 0px; }
+.emoji-1F468-1F469-1F467 { background-position: -12140px 0px; }
+.emoji-1F468-1F469-1F467-1F466 { background-position: -12160px 0px; }
+.emoji-1F468-1F469-1F467-1F467 { background-position: -12180px 0px; }
+.emoji-1F468-2764-1F468 { background-position: -12200px 0px; }
+.emoji-1F468-2764-1F48B-1F468 { background-position: -12220px 0px; }
+.emoji-1F469 { background-position: -12240px 0px; }
+.emoji-1F469-1F469-1F466 { background-position: -12260px 0px; }
+.emoji-1F469-1F469-1F466-1F466 { background-position: -12280px 0px; }
+.emoji-1F469-1F469-1F467 { background-position: -12300px 0px; }
+.emoji-1F469-1F469-1F467-1F466 { background-position: -12320px 0px; }
+.emoji-1F469-1F469-1F467-1F467 { background-position: -12340px 0px; }
+.emoji-1F469-2764-1F469 { background-position: -12360px 0px; }
+.emoji-1F469-2764-1F48B-1F469 { background-position: -12380px 0px; }
+.emoji-1F46A { background-position: -12400px 0px; }
+.emoji-1F46B { background-position: -12420px 0px; }
+.emoji-1F46C { background-position: -12440px 0px; }
+.emoji-1F46D { background-position: -12460px 0px; }
+.emoji-1F46E { background-position: -12480px 0px; }
+.emoji-1F46F { background-position: -12500px 0px; }
+.emoji-1F470 { background-position: -12520px 0px; }
+.emoji-1F471 { background-position: -12540px 0px; }
+.emoji-1F472 { background-position: -12560px 0px; }
+.emoji-1F473 { background-position: -12580px 0px; }
+.emoji-1F474 { background-position: -12600px 0px; }
+.emoji-1F475 { background-position: -12620px 0px; }
+.emoji-1F476 { background-position: -12640px 0px; }
+.emoji-1F477 { background-position: -12660px 0px; }
+.emoji-1F478 { background-position: -12680px 0px; }
+.emoji-1F479 { background-position: -12700px 0px; }
+.emoji-1F47A { background-position: -12720px 0px; }
+.emoji-1F47B { background-position: -12740px 0px; }
+.emoji-1F47C { background-position: -12760px 0px; }
+.emoji-1F47D { background-position: -12780px 0px; }
+.emoji-1F47E { background-position: -12800px 0px; }
+.emoji-1F47F { background-position: -12820px 0px; }
+.emoji-1F480 { background-position: -12840px 0px; }
+.emoji-1F481 { background-position: -12860px 0px; }
+.emoji-1F482 { background-position: -12880px 0px; }
+.emoji-1F483 { background-position: -12900px 0px; }
+.emoji-1F484 { background-position: -12920px 0px; }
+.emoji-1F485 { background-position: -12940px 0px; }
+.emoji-1F486 { background-position: -12960px 0px; }
+.emoji-1F487 { background-position: -12980px 0px; }
+.emoji-1F488 { background-position: -13000px 0px; }
+.emoji-1F489 { background-position: -13020px 0px; }
+.emoji-1F48A { background-position: -13040px 0px; }
+.emoji-1F48B { background-position: -13060px 0px; }
+.emoji-1F48C { background-position: -13080px 0px; }
+.emoji-1F48D { background-position: -13100px 0px; }
+.emoji-1F48E { background-position: -13120px 0px; }
+.emoji-1F48F { background-position: -13140px 0px; }
+.emoji-1F490 { background-position: -13160px 0px; }
+.emoji-1F491 { background-position: -13180px 0px; }
+.emoji-1F492 { background-position: -13200px 0px; }
+.emoji-1F493 { background-position: -13220px 0px; }
+.emoji-1F494 { background-position: -13240px 0px; }
+.emoji-1F495 { background-position: -13260px 0px; }
+.emoji-1F496 { background-position: -13280px 0px; }
+.emoji-1F497 { background-position: -13300px 0px; }
+.emoji-1F498 { background-position: -13320px 0px; }
+.emoji-1F499 { background-position: -13340px 0px; }
+.emoji-1F49A { background-position: -13360px 0px; }
+.emoji-1F49B { background-position: -13380px 0px; }
+.emoji-1F49C { background-position: -13400px 0px; }
+.emoji-1F49D { background-position: -13420px 0px; }
+.emoji-1F49E { background-position: -13440px 0px; }
+.emoji-1F49F { background-position: -13460px 0px; }
+.emoji-1F4A0 { background-position: -13480px 0px; }
+.emoji-1F4A1 { background-position: -13500px 0px; }
+.emoji-1F4A2 { background-position: -13520px 0px; }
+.emoji-1F4A3 { background-position: -13540px 0px; }
+.emoji-1F4A4 { background-position: -13560px 0px; }
+.emoji-1F4A5 { background-position: -13580px 0px; }
+.emoji-1F4A6 { background-position: -13600px 0px; }
+.emoji-1F4A7 { background-position: -13620px 0px; }
+.emoji-1F4A8 { background-position: -13640px 0px; }
+.emoji-1F4A9 { background-position: -13660px 0px; }
+.emoji-1F4AA { background-position: -13680px 0px; }
+.emoji-1F4AB { background-position: -13700px 0px; }
+.emoji-1F4AC { background-position: -13720px 0px; }
+.emoji-1F4AD { background-position: -13740px 0px; }
+.emoji-1F4AE { background-position: -13760px 0px; }
+.emoji-1F4AF { background-position: -13780px 0px; }
+.emoji-1F4B0 { background-position: -13800px 0px; }
+.emoji-1F4B1 { background-position: -13820px 0px; }
+.emoji-1F4B2 { background-position: -13840px 0px; }
+.emoji-1F4B3 { background-position: -13860px 0px; }
+.emoji-1F4B4 { background-position: -13880px 0px; }
+.emoji-1F4B5 { background-position: -13900px 0px; }
+.emoji-1F4B6 { background-position: -13920px 0px; }
+.emoji-1F4B7 { background-position: -13940px 0px; }
+.emoji-1F4B8 { background-position: -13960px 0px; }
+.emoji-1F4B9 { background-position: -13980px 0px; }
+.emoji-1F4BA { background-position: -14000px 0px; }
+.emoji-1F4BB { background-position: -14020px 0px; }
+.emoji-1F4BC { background-position: -14040px 0px; }
+.emoji-1F4BD { background-position: -14060px 0px; }
+.emoji-1F4BE { background-position: -14080px 0px; }
+.emoji-1F4BF { background-position: -14100px 0px; }
+.emoji-1F4C0 { background-position: -14120px 0px; }
+.emoji-1F4C1 { background-position: -14140px 0px; }
+.emoji-1F4C2 { background-position: -14160px 0px; }
+.emoji-1F4C3 { background-position: -14180px 0px; }
+.emoji-1F4C4 { background-position: -14200px 0px; }
+.emoji-1F4C5 { background-position: -14220px 0px; }
+.emoji-1F4C6 { background-position: -14240px 0px; }
+.emoji-1F4C7 { background-position: -14260px 0px; }
+.emoji-1F4C8 { background-position: -14280px 0px; }
+.emoji-1F4C9 { background-position: -14300px 0px; }
+.emoji-1F4CA { background-position: -14320px 0px; }
+.emoji-1F4CB { background-position: -14340px 0px; }
+.emoji-1F4CC { background-position: -14360px 0px; }
+.emoji-1F4CD { background-position: -14380px 0px; }
+.emoji-1F4CE { background-position: -14400px 0px; }
+.emoji-1F4CF { background-position: -14420px 0px; }
+.emoji-1F4D0 { background-position: -14440px 0px; }
+.emoji-1F4D1 { background-position: -14460px 0px; }
+.emoji-1F4D2 { background-position: -14480px 0px; }
+.emoji-1F4D3 { background-position: -14500px 0px; }
+.emoji-1F4D4 { background-position: -14520px 0px; }
+.emoji-1F4D5 { background-position: -14540px 0px; }
+.emoji-1F4D6 { background-position: -14560px 0px; }
+.emoji-1F4D7 { background-position: -14580px 0px; }
+.emoji-1F4D8 { background-position: -14600px 0px; }
+.emoji-1F4D9 { background-position: -14620px 0px; }
+.emoji-1F4DA { background-position: -14640px 0px; }
+.emoji-1F4DB { background-position: -14660px 0px; }
+.emoji-1F4DC { background-position: -14680px 0px; }
+.emoji-1F4DD { background-position: -14700px 0px; }
+.emoji-1F4DE { background-position: -14720px 0px; }
+.emoji-1F4DF { background-position: -14740px 0px; }
+.emoji-1F4E0 { background-position: -14760px 0px; }
+.emoji-1F4E1 { background-position: -14780px 0px; }
+.emoji-1F4E2 { background-position: -14800px 0px; }
+.emoji-1F4E3 { background-position: -14820px 0px; }
+.emoji-1F4E4 { background-position: -14840px 0px; }
+.emoji-1F4E5 { background-position: -14860px 0px; }
+.emoji-1F4E6 { background-position: -14880px 0px; }
+.emoji-1F4E7 { background-position: -14900px 0px; }
+.emoji-1F4E8 { background-position: -14920px 0px; }
+.emoji-1F4E9 { background-position: -14940px 0px; }
+.emoji-1F4EA { background-position: -14960px 0px; }
+.emoji-1F4EB { background-position: -14980px 0px; }
+.emoji-1F4EC { background-position: -15000px 0px; }
+.emoji-1F4ED { background-position: -15020px 0px; }
+.emoji-1F4EE { background-position: -15040px 0px; }
+.emoji-1F4EF { background-position: -15060px 0px; }
+.emoji-1F4F0 { background-position: -15080px 0px; }
+.emoji-1F4F1 { background-position: -15100px 0px; }
+.emoji-1F4F2 { background-position: -15120px 0px; }
+.emoji-1F4F3 { background-position: -15140px 0px; }
+.emoji-1F4F4 { background-position: -15160px 0px; }
+.emoji-1F4F5 { background-position: -15180px 0px; }
+.emoji-1F4F6 { background-position: -15200px 0px; }
+.emoji-1F4F7 { background-position: -15220px 0px; }
+.emoji-1F4F8 { background-position: -15240px 0px; }
+.emoji-1F4F9 { background-position: -15260px 0px; }
+.emoji-1F4FA { background-position: -15280px 0px; }
+.emoji-1F4FB { background-position: -15300px 0px; }
+.emoji-1F4FC { background-position: -15320px 0px; }
+.emoji-1F4FD { background-position: -15340px 0px; }
+.emoji-1F4FE { background-position: -15360px 0px; }
+.emoji-1F500 { background-position: -15380px 0px; }
+.emoji-1F501 { background-position: -15400px 0px; }
+.emoji-1F502 { background-position: -15420px 0px; }
+.emoji-1F503 { background-position: -15440px 0px; }
+.emoji-1F504 { background-position: -15460px 0px; }
+.emoji-1F505 { background-position: -15480px 0px; }
+.emoji-1F506 { background-position: -15500px 0px; }
+.emoji-1F507 { background-position: -15520px 0px; }
+.emoji-1F508 { background-position: -15540px 0px; }
+.emoji-1F509 { background-position: -15560px 0px; }
+.emoji-1F50A { background-position: -15580px 0px; }
+.emoji-1F50B { background-position: -15600px 0px; }
+.emoji-1F50C { background-position: -15620px 0px; }
+.emoji-1F50D { background-position: -15640px 0px; }
+.emoji-1F50E { background-position: -15660px 0px; }
+.emoji-1F50F { background-position: -15680px 0px; }
+.emoji-1F510 { background-position: -15700px 0px; }
+.emoji-1F511 { background-position: -15720px 0px; }
+.emoji-1F512 { background-position: -15740px 0px; }
+.emoji-1F513 { background-position: -15760px 0px; }
+.emoji-1F514 { background-position: -15780px 0px; }
+.emoji-1F515 { background-position: -15800px 0px; }
+.emoji-1F516 { background-position: -15820px 0px; }
+.emoji-1F517 { background-position: -15840px 0px; }
+.emoji-1F518 { background-position: -15860px 0px; }
+.emoji-1F519 { background-position: -15880px 0px; }
+.emoji-1F51A { background-position: -15900px 0px; }
+.emoji-1F51B { background-position: -15920px 0px; }
+.emoji-1F51C { background-position: -15940px 0px; }
+.emoji-1F51D { background-position: -15960px 0px; }
+.emoji-1F51E { background-position: -15980px 0px; }
+.emoji-1F51F { background-position: -16000px 0px; }
+.emoji-1F520 { background-position: -16020px 0px; }
+.emoji-1F521 { background-position: -16040px 0px; }
+.emoji-1F522 { background-position: -16060px 0px; }
+.emoji-1F523 { background-position: -16080px 0px; }
+.emoji-1F524 { background-position: -16100px 0px; }
+.emoji-1F525 { background-position: -16120px 0px; }
+.emoji-1F526 { background-position: -16140px 0px; }
+.emoji-1F527 { background-position: -16160px 0px; }
+.emoji-1F528 { background-position: -16180px 0px; }
+.emoji-1F529 { background-position: -16200px 0px; }
+.emoji-1F52A { background-position: -16220px 0px; }
+.emoji-1F52B { background-position: -16240px 0px; }
+.emoji-1F52C { background-position: -16260px 0px; }
+.emoji-1F52D { background-position: -16280px 0px; }
+.emoji-1F52E { background-position: -16300px 0px; }
+.emoji-1F52F { background-position: -16320px 0px; }
+.emoji-1F530 { background-position: -16340px 0px; }
+.emoji-1F531 { background-position: -16360px 0px; }
+.emoji-1F532 { background-position: -16380px 0px; }
+.emoji-1F533 { background-position: -16400px 0px; }
+.emoji-1F534 { background-position: -16420px 0px; }
+.emoji-1F535 { background-position: -16440px 0px; }
+.emoji-1F536 { background-position: -16460px 0px; }
+.emoji-1F537 { background-position: -16480px 0px; }
+.emoji-1F538 { background-position: -16500px 0px; }
+.emoji-1F539 { background-position: -16520px 0px; }
+.emoji-1F53A { background-position: -16540px 0px; }
+.emoji-1F53B { background-position: -16560px 0px; }
+.emoji-1F53C { background-position: -16580px 0px; }
+.emoji-1F53D { background-position: -16600px 0px; }
+.emoji-1F546 { background-position: -16620px 0px; }
+.emoji-1F547 { background-position: -16640px 0px; }
+.emoji-1F548 { background-position: -16660px 0px; }
+.emoji-1F549 { background-position: -16680px 0px; }
+.emoji-1F54A { background-position: -16700px 0px; }
+.emoji-1F550 { background-position: -16720px 0px; }
+.emoji-1F551 { background-position: -16740px 0px; }
+.emoji-1F552 { background-position: -16760px 0px; }
+.emoji-1F553 { background-position: -16780px 0px; }
+.emoji-1F554 { background-position: -16800px 0px; }
+.emoji-1F555 { background-position: -16820px 0px; }
+.emoji-1F556 { background-position: -16840px 0px; }
+.emoji-1F557 { background-position: -16860px 0px; }
+.emoji-1F558 { background-position: -16880px 0px; }
+.emoji-1F559 { background-position: -16900px 0px; }
+.emoji-1F55A { background-position: -16920px 0px; }
+.emoji-1F55B { background-position: -16940px 0px; }
+.emoji-1F55C { background-position: -16960px 0px; }
+.emoji-1F55D { background-position: -16980px 0px; }
+.emoji-1F55E { background-position: -17000px 0px; }
+.emoji-1F55F { background-position: -17020px 0px; }
+.emoji-1F560 { background-position: -17040px 0px; }
+.emoji-1F561 { background-position: -17060px 0px; }
+.emoji-1F562 { background-position: -17080px 0px; }
+.emoji-1F563 { background-position: -17100px 0px; }
+.emoji-1F564 { background-position: -17120px 0px; }
+.emoji-1F565 { background-position: -17140px 0px; }
+.emoji-1F566 { background-position: -17160px 0px; }
+.emoji-1F567 { background-position: -17180px 0px; }
+.emoji-1F568 { background-position: -17200px 0px; }
+.emoji-1F569 { background-position: -17220px 0px; }
+.emoji-1F56A { background-position: -17240px 0px; }
+.emoji-1F56B { background-position: -17260px 0px; }
+.emoji-1F56C { background-position: -17280px 0px; }
+.emoji-1F56D { background-position: -17300px 0px; }
+.emoji-1F56E { background-position: -17320px 0px; }
+.emoji-1F56F { background-position: -17340px 0px; }
+.emoji-1F570 { background-position: -17360px 0px; }
+.emoji-1F571 { background-position: -17380px 0px; }
+.emoji-1F572 { background-position: -17400px 0px; }
+.emoji-1F573 { background-position: -17420px 0px; }
+.emoji-1F574 { background-position: -17440px 0px; }
+.emoji-1F575 { background-position: -17460px 0px; }
+.emoji-1F576 { background-position: -17480px 0px; }
+.emoji-1F577 { background-position: -17500px 0px; }
+.emoji-1F578 { background-position: -17520px 0px; }
+.emoji-1F579 { background-position: -17540px 0px; }
+.emoji-1F57B { background-position: -17560px 0px; }
+.emoji-1F57E { background-position: -17580px 0px; }
+.emoji-1F57F { background-position: -17600px 0px; }
+.emoji-1F581 { background-position: -17620px 0px; }
+.emoji-1F582 { background-position: -17640px 0px; }
+.emoji-1F583 { background-position: -17660px 0px; }
+.emoji-1F585 { background-position: -17680px 0px; }
+.emoji-1F586 { background-position: -17700px 0px; }
+.emoji-1F587 { background-position: -17720px 0px; }
+.emoji-1F588 { background-position: -17740px 0px; }
+.emoji-1F589 { background-position: -17760px 0px; }
+.emoji-1F58A { background-position: -17780px 0px; }
+.emoji-1F58B { background-position: -17800px 0px; }
+.emoji-1F58C { background-position: -17820px 0px; }
+.emoji-1F58D { background-position: -17840px 0px; }
+.emoji-1F58E { background-position: -17860px 0px; }
+.emoji-1F58F { background-position: -17880px 0px; }
+.emoji-1F590 { background-position: -17900px 0px; }
+.emoji-1F591 { background-position: -17920px 0px; }
+.emoji-1F592 { background-position: -17940px 0px; }
+.emoji-1F593 { background-position: -17960px 0px; }
+.emoji-1F594 { background-position: -17980px 0px; }
+.emoji-1F595 { background-position: -18000px 0px; }
+.emoji-1F596 { background-position: -18020px 0px; }
+.emoji-1F597 { background-position: -18040px 0px; }
+.emoji-1F598 { background-position: -18060px 0px; }
+.emoji-1F599 { background-position: -18080px 0px; }
+.emoji-1F59E { background-position: -18100px 0px; }
+.emoji-1F59F { background-position: -18120px 0px; }
+.emoji-1F5A5 { background-position: -18140px 0px; }
+.emoji-1F5A6 { background-position: -18160px 0px; }
+.emoji-1F5A7 { background-position: -18180px 0px; }
+.emoji-1F5A8 { background-position: -18200px 0px; }
+.emoji-1F5A9 { background-position: -18220px 0px; }
+.emoji-1F5AA { background-position: -18240px 0px; }
+.emoji-1F5AB { background-position: -18260px 0px; }
+.emoji-1F5AD { background-position: -18280px 0px; }
+.emoji-1F5AE { background-position: -18300px 0px; }
+.emoji-1F5AF { background-position: -18320px 0px; }
+.emoji-1F5B2 { background-position: -18340px 0px; }
+.emoji-1F5B3 { background-position: -18360px 0px; }
+.emoji-1F5B4 { background-position: -18380px 0px; }
+.emoji-1F5B8 { background-position: -18400px 0px; }
+.emoji-1F5B9 { background-position: -18420px 0px; }
+.emoji-1F5BC { background-position: -18440px 0px; }
+.emoji-1F5BD { background-position: -18460px 0px; }
+.emoji-1F5BE { background-position: -18480px 0px; }
+.emoji-1F5C0 { background-position: -18500px 0px; }
+.emoji-1F5C1 { background-position: -18520px 0px; }
+.emoji-1F5C2 { background-position: -18540px 0px; }
+.emoji-1F5C3 { background-position: -18560px 0px; }
+.emoji-1F5C4 { background-position: -18580px 0px; }
+.emoji-1F5C6 { background-position: -18600px 0px; }
+.emoji-1F5C7 { background-position: -18620px 0px; }
+.emoji-1F5C9 { background-position: -18640px 0px; }
+.emoji-1F5CA { background-position: -18660px 0px; }
+.emoji-1F5CE { background-position: -18680px 0px; }
+.emoji-1F5CF { background-position: -18700px 0px; }
+.emoji-1F5D0 { background-position: -18720px 0px; }
+.emoji-1F5D1 { background-position: -18740px 0px; }
+.emoji-1F5D2 { background-position: -18760px 0px; }
+.emoji-1F5D3 { background-position: -18780px 0px; }
+.emoji-1F5D4 { background-position: -18800px 0px; }
+.emoji-1F5D8 { background-position: -18820px 0px; }
+.emoji-1F5D9 { background-position: -18840px 0px; }
+.emoji-1F5DC { background-position: -18860px 0px; }
+.emoji-1F5DD { background-position: -18880px 0px; }
+.emoji-1F5DE { background-position: -18900px 0px; }
+.emoji-1F5E0 { background-position: -18920px 0px; }
+.emoji-1F5E1 { background-position: -18940px 0px; }
+.emoji-1F5E2 { background-position: -18960px 0px; }
+.emoji-1F5E3 { background-position: -18980px 0px; }
+.emoji-1F5E8 { background-position: -19000px 0px; }
+.emoji-1F5E9 { background-position: -19020px 0px; }
+.emoji-1F5EA { background-position: -19040px 0px; }
+.emoji-1F5EB { background-position: -19060px 0px; }
+.emoji-1F5EC { background-position: -19080px 0px; }
+.emoji-1F5ED { background-position: -19100px 0px; }
+.emoji-1F5EE { background-position: -19120px 0px; }
+.emoji-1F5EF { background-position: -19140px 0px; }
+.emoji-1F5F0 { background-position: -19160px 0px; }
+.emoji-1F5F1 { background-position: -19180px 0px; }
+.emoji-1F5F2 { background-position: -19200px 0px; }
+.emoji-1F5F3 { background-position: -19220px 0px; }
+.emoji-1F5F4 { background-position: -19240px 0px; }
+.emoji-1F5F5 { background-position: -19260px 0px; }
+.emoji-1F5F8 { background-position: -19280px 0px; }
+.emoji-1F5F9 { background-position: -19300px 0px; }
+.emoji-1F5FA { background-position: -19320px 0px; }
+.emoji-1F5FB { background-position: -19340px 0px; }
+.emoji-1F5FC { background-position: -19360px 0px; }
+.emoji-1F5FD { background-position: -19380px 0px; }
+.emoji-1F5FE { background-position: -19400px 0px; }
+.emoji-1F5FF { background-position: -19420px 0px; }
+.emoji-1F600 { background-position: -19440px 0px; }
+.emoji-1F601 { background-position: -19460px 0px; }
+.emoji-1F602 { background-position: -19480px 0px; }
+.emoji-1F603 { background-position: -19500px 0px; }
+.emoji-1F604 { background-position: -19520px 0px; }
+.emoji-1F605 { background-position: -19540px 0px; }
+.emoji-1F606 { background-position: -19560px 0px; }
+.emoji-1F607 { background-position: -19580px 0px; }
+.emoji-1F608 { background-position: -19600px 0px; }
+.emoji-1F609 { background-position: -19620px 0px; }
+.emoji-1F60A { background-position: -19640px 0px; }
+.emoji-1F60B { background-position: -19660px 0px; }
+.emoji-1F60C { background-position: -19680px 0px; }
+.emoji-1F60D { background-position: -19700px 0px; }
+.emoji-1F60E { background-position: -19720px 0px; }
+.emoji-1F60F { background-position: -19740px 0px; }
+.emoji-1F610 { background-position: -19760px 0px; }
+.emoji-1F611 { background-position: -19780px 0px; }
+.emoji-1F612 { background-position: -19800px 0px; }
+.emoji-1F613 { background-position: -19820px 0px; }
+.emoji-1F614 { background-position: -19840px 0px; }
+.emoji-1F615 { background-position: -19860px 0px; }
+.emoji-1F616 { background-position: -19880px 0px; }
+.emoji-1F617 { background-position: -19900px 0px; }
+.emoji-1F618 { background-position: -19920px 0px; }
+.emoji-1F619 { background-position: -19940px 0px; }
+.emoji-1F61A { background-position: -19960px 0px; }
+.emoji-1F61B { background-position: -19980px 0px; }
+.emoji-1F61C { background-position: -20000px 0px; }
+.emoji-1F61D { background-position: -20020px 0px; }
+.emoji-1F61E { background-position: -20040px 0px; }
+.emoji-1F61F { background-position: -20060px 0px; }
+.emoji-1F620 { background-position: -20080px 0px; }
+.emoji-1F621 { background-position: -20100px 0px; }
+.emoji-1F622 { background-position: -20120px 0px; }
+.emoji-1F623 { background-position: -20140px 0px; }
+.emoji-1F624 { background-position: -20160px 0px; }
+.emoji-1F625 { background-position: -20180px 0px; }
+.emoji-1F626 { background-position: -20200px 0px; }
+.emoji-1F627 { background-position: -20220px 0px; }
+.emoji-1F628 { background-position: -20240px 0px; }
+.emoji-1F629 { background-position: -20260px 0px; }
+.emoji-1F62A { background-position: -20280px 0px; }
+.emoji-1F62B { background-position: -20300px 0px; }
+.emoji-1F62C { background-position: -20320px 0px; }
+.emoji-1F62D { background-position: -20340px 0px; }
+.emoji-1F62E { background-position: -20360px 0px; }
+.emoji-1F62F { background-position: -20380px 0px; }
+.emoji-1F630 { background-position: -20400px 0px; }
+.emoji-1F631 { background-position: -20420px 0px; }
+.emoji-1F632 { background-position: -20440px 0px; }
+.emoji-1F633 { background-position: -20460px 0px; }
+.emoji-1F634 { background-position: -20480px 0px; }
+.emoji-1F635 { background-position: -20500px 0px; }
+.emoji-1F636 { background-position: -20520px 0px; }
+.emoji-1F637 { background-position: -20540px 0px; }
+.emoji-1F638 { background-position: -20560px 0px; }
+.emoji-1F639 { background-position: -20580px 0px; }
+.emoji-1F63A { background-position: -20600px 0px; }
+.emoji-1F63B { background-position: -20620px 0px; }
+.emoji-1F63C { background-position: -20640px 0px; }
+.emoji-1F63D { background-position: -20660px 0px; }
+.emoji-1F63E { background-position: -20680px 0px; }
+.emoji-1F63F { background-position: -20700px 0px; }
+.emoji-1F640 { background-position: -20720px 0px; }
+.emoji-1F641 { background-position: -20740px 0px; }
+.emoji-1F642 { background-position: -20760px 0px; }
+.emoji-1F645 { background-position: -20780px 0px; }
+.emoji-1F646 { background-position: -20800px 0px; }
+.emoji-1F647 { background-position: -20820px 0px; }
+.emoji-1F648 { background-position: -20840px 0px; }
+.emoji-1F649 { background-position: -20860px 0px; }
+.emoji-1F64A { background-position: -20880px 0px; }
+.emoji-1F64B { background-position: -20900px 0px; }
+.emoji-1F64C { background-position: -20920px 0px; }
+.emoji-1F64D { background-position: -20940px 0px; }
+.emoji-1F64E { background-position: -20960px 0px; }
+.emoji-1F64F { background-position: -20980px 0px; }
+.emoji-1F680 { background-position: -21000px 0px; }
+.emoji-1F681 { background-position: -21020px 0px; }
+.emoji-1F682 { background-position: -21040px 0px; }
+.emoji-1F683 { background-position: -21060px 0px; }
+.emoji-1F684 { background-position: -21080px 0px; }
+.emoji-1F685 { background-position: -21100px 0px; }
+.emoji-1F686 { background-position: -21120px 0px; }
+.emoji-1F687 { background-position: -21140px 0px; }
+.emoji-1F688 { background-position: -21160px 0px; }
+.emoji-1F689 { background-position: -21180px 0px; }
+.emoji-1F68A { background-position: -21200px 0px; }
+.emoji-1F68B { background-position: -21220px 0px; }
+.emoji-1F68C { background-position: -21240px 0px; }
+.emoji-1F68D { background-position: -21260px 0px; }
+.emoji-1F68E { background-position: -21280px 0px; }
+.emoji-1F68F { background-position: -21300px 0px; }
+.emoji-1F690 { background-position: -21320px 0px; }
+.emoji-1F691 { background-position: -21340px 0px; }
+.emoji-1F692 { background-position: -21360px 0px; }
+.emoji-1F693 { background-position: -21380px 0px; }
+.emoji-1F694 { background-position: -21400px 0px; }
+.emoji-1F695 { background-position: -21420px 0px; }
+.emoji-1F696 { background-position: -21440px 0px; }
+.emoji-1F697 { background-position: -21460px 0px; }
+.emoji-1F698 { background-position: -21480px 0px; }
+.emoji-1F699 { background-position: -21500px 0px; }
+.emoji-1F69A { background-position: -21520px 0px; }
+.emoji-1F69B { background-position: -21540px 0px; }
+.emoji-1F69C { background-position: -21560px 0px; }
+.emoji-1F69D { background-position: -21580px 0px; }
+.emoji-1F69E { background-position: -21600px 0px; }
+.emoji-1F69F { background-position: -21620px 0px; }
+.emoji-1F6A0 { background-position: -21640px 0px; }
+.emoji-1F6A1 { background-position: -21660px 0px; }
+.emoji-1F6A2 { background-position: -21680px 0px; }
+.emoji-1F6A3 { background-position: -21700px 0px; }
+.emoji-1F6A4 { background-position: -21720px 0px; }
+.emoji-1F6A5 { background-position: -21740px 0px; }
+.emoji-1F6A6 { background-position: -21760px 0px; }
+.emoji-1F6A7 { background-position: -21780px 0px; }
+.emoji-1F6A8 { background-position: -21800px 0px; }
+.emoji-1F6A9 { background-position: -21820px 0px; }
+.emoji-1F6AA { background-position: -21840px 0px; }
+.emoji-1F6AB { background-position: -21860px 0px; }
+.emoji-1F6AC { background-position: -21880px 0px; }
+.emoji-1F6AD { background-position: -21900px 0px; }
+.emoji-1F6AE { background-position: -21920px 0px; }
+.emoji-1F6AF { background-position: -21940px 0px; }
+.emoji-1F6B0 { background-position: -21960px 0px; }
+.emoji-1F6B1 { background-position: -21980px 0px; }
+.emoji-1F6B2 { background-position: -22000px 0px; }
+.emoji-1F6B3 { background-position: -22020px 0px; }
+.emoji-1F6B4 { background-position: -22040px 0px; }
+.emoji-1F6B5 { background-position: -22060px 0px; }
+.emoji-1F6B6 { background-position: -22080px 0px; }
+.emoji-1F6B7 { background-position: -22100px 0px; }
+.emoji-1F6B8 { background-position: -22120px 0px; }
+.emoji-1F6B9 { background-position: -22140px 0px; }
+.emoji-1F6BA { background-position: -22160px 0px; }
+.emoji-1F6BB { background-position: -22180px 0px; }
+.emoji-1F6BC { background-position: -22200px 0px; }
+.emoji-1F6BD { background-position: -22220px 0px; }
+.emoji-1F6BE { background-position: -22240px 0px; }
+.emoji-1F6BF { background-position: -22260px 0px; }
+.emoji-1F6C0 { background-position: -22280px 0px; }
+.emoji-1F6C1 { background-position: -22300px 0px; }
+.emoji-1F6C2 { background-position: -22320px 0px; }
+.emoji-1F6C3 { background-position: -22340px 0px; }
+.emoji-1F6C4 { background-position: -22360px 0px; }
+.emoji-1F6C5 { background-position: -22380px 0px; }
+.emoji-1F6C6 { background-position: -22400px 0px; }
+.emoji-1F6C7 { background-position: -22420px 0px; }
+.emoji-1F6C8 { background-position: -22440px 0px; }
+.emoji-1F6C9 { background-position: -22460px 0px; }
+.emoji-1F6CA { background-position: -22480px 0px; }
+.emoji-1F6CB { background-position: -22500px 0px; }
+.emoji-1F6CC { background-position: -22520px 0px; }
+.emoji-1F6CD { background-position: -22540px 0px; }
+.emoji-1F6CE { background-position: -22560px 0px; }
+.emoji-1F6CF { background-position: -22580px 0px; }
+.emoji-1F6E0 { background-position: -22600px 0px; }
+.emoji-1F6E1 { background-position: -22620px 0px; }
+.emoji-1F6E2 { background-position: -22640px 0px; }
+.emoji-1F6E3 { background-position: -22660px 0px; }
+.emoji-1F6E4 { background-position: -22680px 0px; }
+.emoji-1F6E5 { background-position: -22700px 0px; }
+.emoji-1F6E6 { background-position: -22720px 0px; }
+.emoji-1F6E7 { background-position: -22740px 0px; }
+.emoji-1F6E8 { background-position: -22760px 0px; }
+.emoji-1F6E9 { background-position: -22780px 0px; }
+.emoji-1F6EA { background-position: -22800px 0px; }
+.emoji-1F6EB { background-position: -22820px 0px; }
+.emoji-1F6EC { background-position: -22840px 0px; }
+.emoji-1F6F0 { background-position: -22860px 0px; }
+.emoji-1F6F1 { background-position: -22880px 0px; }
+.emoji-1F6F2 { background-position: -22900px 0px; }
+.emoji-1F6F3 { background-position: -22920px 0px; }
+.emoji-203C { background-position: -22940px 0px; }
+.emoji-2049 { background-position: -22960px 0px; }
+.emoji-2122 { background-position: -22980px 0px; }
+.emoji-2139 { background-position: -23000px 0px; }
+.emoji-2194 { background-position: -23020px 0px; }
+.emoji-2195 { background-position: -23040px 0px; }
+.emoji-2196 { background-position: -23060px 0px; }
+.emoji-2197 { background-position: -23080px 0px; }
+.emoji-2198 { background-position: -23100px 0px; }
+.emoji-2199 { background-position: -23120px 0px; }
+.emoji-21A9 { background-position: -23140px 0px; }
+.emoji-21AA { background-position: -23160px 0px; }
+.emoji-231A { background-position: -23180px 0px; }
+.emoji-231B { background-position: -23200px 0px; }
+.emoji-23E9 { background-position: -23220px 0px; }
+.emoji-23EA { background-position: -23240px 0px; }
+.emoji-23EB { background-position: -23260px 0px; }
+.emoji-23EC { background-position: -23280px 0px; }
+.emoji-23F0 { background-position: -23300px 0px; }
+.emoji-23F3 { background-position: -23320px 0px; }
+.emoji-24C2 { background-position: -23340px 0px; }
+.emoji-25AA { background-position: -23360px 0px; }
+.emoji-25AB { background-position: -23380px 0px; }
+.emoji-25B6 { background-position: -23400px 0px; }
+.emoji-25C0 { background-position: -23420px 0px; }
+.emoji-25FB { background-position: -23440px 0px; }
+.emoji-25FC { background-position: -23460px 0px; }
+.emoji-25FD { background-position: -23480px 0px; }
+.emoji-25FE { background-position: -23500px 0px; }
+.emoji-2600 { background-position: -23520px 0px; }
+.emoji-2601 { background-position: -23540px 0px; }
+.emoji-260E { background-position: -23560px 0px; }
+.emoji-2611 { background-position: -23580px 0px; }
+.emoji-2614 { background-position: -23600px 0px; }
+.emoji-2615 { background-position: -23620px 0px; }
+.emoji-261D { background-position: -23640px 0px; }
+.emoji-263A { background-position: -23660px 0px; }
+.emoji-2648 { background-position: -23680px 0px; }
+.emoji-2649 { background-position: -23700px 0px; }
+.emoji-264A { background-position: -23720px 0px; }
+.emoji-264B { background-position: -23740px 0px; }
+.emoji-264C { background-position: -23760px 0px; }
+.emoji-264D { background-position: -23780px 0px; }
+.emoji-264E { background-position: -23800px 0px; }
+.emoji-264F { background-position: -23820px 0px; }
+.emoji-2650 { background-position: -23840px 0px; }
+.emoji-2651 { background-position: -23860px 0px; }
+.emoji-2652 { background-position: -23880px 0px; }
+.emoji-2653 { background-position: -23900px 0px; }
+.emoji-2660 { background-position: -23920px 0px; }
+.emoji-2663 { background-position: -23940px 0px; }
+.emoji-2665 { background-position: -23960px 0px; }
+.emoji-2666 { background-position: -23980px 0px; }
+.emoji-2668 { background-position: -24000px 0px; }
+.emoji-267B { background-position: -24020px 0px; }
+.emoji-267F { background-position: -24040px 0px; }
+.emoji-2693 { background-position: -24060px 0px; }
+.emoji-26A0 { background-position: -24080px 0px; }
+.emoji-26A1 { background-position: -24100px 0px; }
+.emoji-26AA { background-position: -24120px 0px; }
+.emoji-26AB { background-position: -24140px 0px; }
+.emoji-26BD { background-position: -24160px 0px; }
+.emoji-26BE { background-position: -24180px 0px; }
+.emoji-26C4 { background-position: -24200px 0px; }
+.emoji-26C5 { background-position: -24220px 0px; }
+.emoji-26CE { background-position: -24240px 0px; }
+.emoji-26D4 { background-position: -24260px 0px; }
+.emoji-26EA { background-position: -24280px 0px; }
+.emoji-26F2 { background-position: -24300px 0px; }
+.emoji-26F3 { background-position: -24320px 0px; }
+.emoji-26F5 { background-position: -24340px 0px; }
+.emoji-26FA { background-position: -24360px 0px; }
+.emoji-26FD { background-position: -24380px 0px; }
+.emoji-2702 { background-position: -24400px 0px; }
+.emoji-2705 { background-position: -24420px 0px; }
+.emoji-2708 { background-position: -24440px 0px; }
+.emoji-2709 { background-position: -24460px 0px; }
+.emoji-270A { background-position: -24480px 0px; }
+.emoji-270B { background-position: -24500px 0px; }
+.emoji-270C { background-position: -24520px 0px; }
+.emoji-270F { background-position: -24540px 0px; }
+.emoji-2712 { background-position: -24560px 0px; }
+.emoji-2714 { background-position: -24580px 0px; }
+.emoji-2716 { background-position: -24600px 0px; }
+.emoji-2728 { background-position: -24620px 0px; }
+.emoji-2733 { background-position: -24640px 0px; }
+.emoji-2734 { background-position: -24660px 0px; }
+.emoji-2744 { background-position: -24680px 0px; }
+.emoji-2747 { background-position: -24700px 0px; }
+.emoji-274C { background-position: -24720px 0px; }
+.emoji-274E { background-position: -24740px 0px; }
+.emoji-2753 { background-position: -24760px 0px; }
+.emoji-2754 { background-position: -24780px 0px; }
+.emoji-2755 { background-position: -24800px 0px; }
+.emoji-2757 { background-position: -24820px 0px; }
+.emoji-2764 { background-position: -24840px 0px; }
+.emoji-2795 { background-position: -24860px 0px; }
+.emoji-2796 { background-position: -24880px 0px; }
+.emoji-2797 { background-position: -24900px 0px; }
+.emoji-27A1 { background-position: -24920px 0px; }
+.emoji-27B0 { background-position: -24940px 0px; }
+.emoji-27BF { background-position: -24960px 0px; }
+.emoji-2934 { background-position: -24980px 0px; }
+.emoji-2935 { background-position: -25000px 0px; }
+.emoji-2B05 { background-position: -25020px 0px; }
+.emoji-2B06 { background-position: -25040px 0px; }
+.emoji-2B07 { background-position: -25060px 0px; }
+.emoji-2B1B { background-position: -25080px 0px; }
+.emoji-2B1C { background-position: -25100px 0px; }
+.emoji-2B50 { background-position: -25120px 0px; }
+.emoji-2B55 { background-position: -25140px 0px; }
+.emoji-3030 { background-position: -25160px 0px; }
+.emoji-303D { background-position: -25180px 0px; }
+.emoji-3297 { background-position: -25200px 0px; }
+.emoji-3299 { background-position: -25220px 0px; }
\ No newline at end of file
diff --git a/app/assets/stylesheets/pages/note_form.scss b/app/assets/stylesheets/pages/note_form.scss
index 4cf1a28c459f33a277d855500e51a8837cad64cf..d86259f93fbcfe672cf0fab9d84d03ad196a21fe 100644
--- a/app/assets/stylesheets/pages/note_form.scss
+++ b/app/assets/stylesheets/pages/note_form.scss
@@ -75,16 +75,15 @@
 
 .common-note-form {
   margin: 0;
-  background: #F7F8FA;
+  background: #fff;
   padding: $gl-padding;
   margin-left: -$gl-padding;
   margin-right: -$gl-padding;
-  border-top: 1px solid $border-color;
   margin-bottom: -$gl-padding;
 }
 
 .note-form-actions {
-  background: #F9F9F9;
+  background: #fff;
 
   .note-form-option {
     margin-top: 8px;
diff --git a/app/assets/stylesheets/pages/notes.scss b/app/assets/stylesheets/pages/notes.scss
index 4dff87abaa4ec2d556c336014544c62cefcebf25..72b0ed29a698b1d2e95b79c8c654f61784a2165f 100644
--- a/app/assets/stylesheets/pages/notes.scss
+++ b/app/assets/stylesheets/pages/notes.scss
@@ -128,7 +128,7 @@ ul.notes {
     }
 
     &:last-child {
-      border-bottom: none;
+      border-bottom: 1px solid $border-color;
     }
   }
 }
diff --git a/app/assets/stylesheets/pages/projects.scss b/app/assets/stylesheets/pages/projects.scss
index 2ded32dba123746e77ff1d319852ac21f3ad1755..cff3edb7ed26c2a5caa0a062001c5af7d705017f 100644
--- a/app/assets/stylesheets/pages/projects.scss
+++ b/app/assets/stylesheets/pages/projects.scss
@@ -91,21 +91,83 @@
     }
   }
 
-  .input-group {
+  .git-clone-holder {
     display: inline-table;
     position: relative;
-    top: 17px;
   }
 
   .project-repo-buttons {
     margin-top: 12px;
     margin-bottom: 0px;
 
+    .count-buttons {
+      display: block;
+      margin-bottom: 12px;
+    }
+
     .btn {
       @include btn-gray;
-
+      text-transform: none;
+    }
+    .count-with-arrow {
+      display: inline-block;
+      position: relative;
+      margin-left: 4px;
+
+      .arrow {
+        &:before {
+          content: '';
+          display: inline-block;
+          position: absolute;
+          width: 0;
+          height: 0;
+          border-color: transparent;
+          border-style: solid;
+          top: 50%;
+          left: 0;
+          margin-top: -6px;
+          border-width: 7px 5px 7px 0;
+          border-right-color: #dce0e5;
+        }
+
+        &:after {
+          content: '';
+          position: absolute;
+          width: 0;
+          height: 0;
+          border-color: transparent;
+          border-style: solid;
+          top: 50%;
+          left: 1px;
+          margin-top: -9px;
+          border-width: 10px 7px 10px 0;
+          border-right-color: #FFF;
+        }
+      }
       .count {
+        @include btn-gray;
         display: inline-block;
+        background: white;
+        border-radius: 2px;
+        border-width: 1px;
+        border-style: solid;
+        font-size: 13px;
+        font-weight: 600;
+        line-height: 20px;
+        padding: 11px 16px;
+        letter-spacing: .4px;
+        padding: 10px;
+        text-align: center;
+        vertical-align: middle;
+        touch-action: manipulation;
+        cursor: pointer;
+        background-image: none;
+        white-space: nowrap;
+        margin: 0 11px 0px 4px;
+
+        &:hover {
+          background: #FFF;
+        }
       }
     }
   }
@@ -125,6 +187,13 @@
     margin-right: 45px;
   }
 
+  .clone-options {
+    display: table-cell;
+    a.btn {
+      width: 100%;
+    }
+  }
+
   .form-control {
     cursor: auto;
     @extend .monospace;
@@ -335,6 +404,38 @@ ul.nav.nav-projects-tabs {
   }
 }
 
+.top-area {
+  border-bottom: 1px solid #EEE;
+  margin: 0 -16px;
+  padding: 0 $gl-padding;
+
+  ul.left-top-menu {
+    display: inline-block;
+    width: 50%;
+    margin-bottom: 0px;
+    border-bottom: none;
+  }
+
+  .projects-search-form {
+    width: 50%;
+    display: inline-block;
+    float: right;
+    padding-top: 7px;
+    text-align: right;
+
+    .btn-green {
+      margin-top: -2px;
+      margin-left: 10px;
+    }
+  }
+
+  @media (max-width: $screen-xs-max) {
+    .projects-search-form {
+      padding-top: 15px;
+    }
+  }
+}
+
 .fork-namespaces {
   .fork-thumbnail {
     text-align: center;
@@ -412,11 +513,18 @@ pre.light-well {
 
 .projects-search-form {
   margin: -$gl-padding;
-  background-color: #f8fafc;
   padding: $gl-padding;
   margin-bottom: 0px;
-  border-top: 1px solid #e7e9ed;
-  border-bottom: 1px solid #e7e9ed;
+
+  input {
+    display: inline-block;
+    width: calc(100% - 151px);
+  }
+
+  .btn {
+    display: inline-block;
+    width: 135px;
+  }
 }
 
 .git-empty {
diff --git a/app/controllers/admin/identities_controller.rb b/app/controllers/admin/identities_controller.rb
index d28614731f9211cf66fb1ef3af5e76a2c3fe972d..e383fe38ea68352c5ba172a396a978f805a27527 100644
--- a/app/controllers/admin/identities_controller.rb
+++ b/app/controllers/admin/identities_controller.rb
@@ -1,6 +1,21 @@
 class Admin::IdentitiesController < Admin::ApplicationController
   before_action :user
-  before_action :identity, except: :index
+  before_action :identity, except: [:index, :new, :create]
+
+  def new
+    @identity = Identity.new
+  end
+
+  def create
+    @identity = Identity.new(identity_params)
+    @identity.user_id = user.id
+
+    if @identity.save
+      redirect_to admin_user_identities_path(@user), notice: 'User identity was successfully created.'
+    else
+      render :new
+    end
+  end
 
   def index
     @identities = @user.identities
diff --git a/app/controllers/application_controller.rb b/app/controllers/application_controller.rb
index 0d182e8eb04d92fded1152636459a9be917d82c1..01e2e7b2f980c3f544f7e34cc977923666ef5cf3 100644
--- a/app/controllers/application_controller.rb
+++ b/app/controllers/application_controller.rb
@@ -10,6 +10,7 @@ class ApplicationController < ActionController::Base
 
   before_action :authenticate_user_from_token!
   before_action :authenticate_user!
+  before_action :validate_user_service_ticket!
   before_action :reject_blocked!
   before_action :check_password_expiration
   before_action :ldap_security_check
@@ -202,6 +203,20 @@ class ApplicationController < ActionController::Base
     end
   end
 
+  def validate_user_service_ticket!
+    return unless signed_in? && session[:service_tickets]
+
+    valid = session[:service_tickets].all? do |provider, ticket|
+      Gitlab::OAuth::Session.valid?(provider, ticket)
+    end
+
+    unless valid
+      session[:service_tickets] = nil
+      sign_out current_user
+      redirect_to new_user_session_path
+    end
+  end
+
   def check_password_expiration
     if current_user && current_user.password_expires_at && current_user.password_expires_at < Time.now  && !current_user.ldap_user?
       redirect_to new_profile_password_path and return
diff --git a/app/controllers/ci/lints_controller.rb b/app/controllers/ci/lints_controller.rb
index 7ed78ff8e989492249818665fc8ae1a7c6ea5784..e782a51e7eb93dce8ca605dd2236cd749a272119 100644
--- a/app/controllers/ci/lints_controller.rb
+++ b/app/controllers/ci/lints_controller.rb
@@ -19,8 +19,10 @@ module Ci
       @error = e.message
       @status = false
     rescue
-      @error = "Undefined error"
+      @error = 'Undefined error'
       @status = false
+    ensure
+      render :show
     end
   end
 end
diff --git a/app/controllers/concerns/creates_commit.rb b/app/controllers/concerns/creates_commit.rb
new file mode 100644
index 0000000000000000000000000000000000000000..62127a090817e01355ec314399db321c0d378a56
--- /dev/null
+++ b/app/controllers/concerns/creates_commit.rb
@@ -0,0 +1,103 @@
+module CreatesCommit
+  extend ActiveSupport::Concern
+
+  def create_commit(service, success_path:, failure_path:, failure_view: nil, success_notice: nil)
+    set_commit_variables
+
+    commit_params = @commit_params.merge(
+      source_project: @project,
+      source_branch: @ref,
+      target_branch: @target_branch
+    )
+
+    result = service.new(@tree_edit_project, current_user, commit_params).execute
+
+    if result[:status] == :success
+      flash[:notice] = success_notice || "Your changes have been successfully committed."
+
+      if create_merge_request?
+        success_path = new_merge_request_path
+        target = different_project? ? "project" : "branch"
+        flash[:notice] << " You can now submit a merge request to get this change into the original #{target}."
+      end
+
+      respond_to do |format|
+        format.html { redirect_to success_path }
+        format.json { render json: { message: "success", filePath: success_path } }
+      end
+    else
+      flash[:alert] = result[:message]
+      respond_to do |format|
+        format.html do
+          if failure_view
+            render failure_view
+          else
+            redirect_to failure_path
+          end
+        end
+        format.json { render json: { message: "failed", filePath: failure_path } }
+      end
+    end
+  end
+
+  def authorize_edit_tree!
+    return if can?(current_user, :push_code, project)
+    return if current_user && current_user.already_forked?(project)
+
+    access_denied!
+  end
+
+  private
+
+  def new_merge_request_path
+    new_namespace_project_merge_request_path(
+      @mr_source_project.namespace,
+      @mr_source_project,
+      merge_request: {
+        source_project_id: @mr_source_project.id,
+        target_project_id: @mr_target_project.id,
+        source_branch: @mr_source_branch,
+        target_branch: @mr_target_branch
+      }
+    )
+  end
+
+  def different_project?
+    @mr_source_project != @mr_target_project
+  end
+
+  def different_branch?
+    @mr_source_branch != @mr_target_branch || different_project?
+  end
+
+  def create_merge_request?
+    params[:create_merge_request].present? && different_branch?
+  end
+
+  def set_commit_variables
+    @mr_source_branch = @target_branch
+
+    if can?(current_user, :push_code, @project)
+      # Edit file in this project
+      @tree_edit_project = @project
+      @mr_source_project = @project
+
+      if @project.forked?
+        # Merge request from this project to fork origin
+        @mr_target_project = @project.forked_from_project
+        @mr_target_branch = @mr_target_project.repository.root_ref
+      else
+        # Merge request to this project
+        @mr_target_project = @project
+        @mr_target_branch = @ref
+      end
+    else
+      # Edit file in fork
+      @tree_edit_project = current_user.fork_of(@project)
+      # Merge request from fork to this project
+      @mr_source_project = @tree_edit_project
+      @mr_target_project = @project
+      @mr_target_branch = @mr_target_project.repository.root_ref
+    end
+  end
+end
diff --git a/app/controllers/concerns/creates_merge_request_for_commit.rb b/app/controllers/concerns/creates_merge_request_for_commit.rb
deleted file mode 100644
index c75278221585a95a18e591f63c1e7839727ace7a..0000000000000000000000000000000000000000
--- a/app/controllers/concerns/creates_merge_request_for_commit.rb
+++ /dev/null
@@ -1,28 +0,0 @@
-module CreatesMergeRequestForCommit
-  extend ActiveSupport::Concern
-
-  def new_merge_request_path
-    if @project.forked?
-      target_project = @project.forked_from_project || @project
-      target_branch = target_project.repository.root_ref
-    else
-      target_project = @project
-      target_branch = @ref
-    end
-
-    new_namespace_project_merge_request_path(
-      @project.namespace,
-      @project,
-      merge_request: {
-        source_project_id: @project.id,
-        target_project_id: target_project.id,
-        source_branch: @new_branch,
-        target_branch: target_branch
-      }
-    )
-  end
-
-  def create_merge_request?
-    params[:create_merge_request] && @new_branch != @ref
-  end
-end
diff --git a/app/controllers/omniauth_callbacks_controller.rb b/app/controllers/omniauth_callbacks_controller.rb
index f809fa7500a09fd37a547238198987e80501f5ea..4cad98b8e98bdd7044ed442ea0622418e14f016a 100644
--- a/app/controllers/omniauth_callbacks_controller.rb
+++ b/app/controllers/omniauth_callbacks_controller.rb
@@ -1,6 +1,6 @@
 class OmniauthCallbacksController < Devise::OmniauthCallbacksController
 
-  protect_from_forgery except: [:kerberos, :saml]
+  protect_from_forgery except: [:kerberos, :saml, :cas3]
 
   Gitlab.config.omniauth.providers.each do |provider|
     define_method provider['name'] do
@@ -42,6 +42,14 @@ class OmniauthCallbacksController < Devise::OmniauthCallbacksController
     render 'errors/omniauth_error', layout: "errors", status: 422
   end
 
+  def cas3
+    ticket = params['ticket']
+    if ticket
+      handle_service_ticket oauth['provider'], ticket
+    end
+    handle_omniauth
+  end
+
   private
 
   def handle_omniauth
@@ -84,6 +92,12 @@ class OmniauthCallbacksController < Devise::OmniauthCallbacksController
     redirect_to new_user_session_path
   end
 
+  def handle_service_ticket provider, ticket
+    Gitlab::OAuth::Session.create provider, ticket
+    session[:service_tickets] ||= {}
+    session[:service_tickets][provider] = ticket
+  end
+
   def oauth
     @oauth ||= request.env['omniauth.auth']
   end
diff --git a/app/controllers/projects/blob_controller.rb b/app/controllers/projects/blob_controller.rb
index 6216368293637cbd528cb589f0f25e573cf785c7..c56a3497bb2d096cb00231fa979148c0c22c8037 100644
--- a/app/controllers/projects/blob_controller.rb
+++ b/app/controllers/projects/blob_controller.rb
@@ -1,7 +1,7 @@
 # Controller for viewing a file's blame
 class Projects::BlobController < Projects::ApplicationController
   include ExtractsPath
-  include CreatesMergeRequestForCommit
+  include CreatesCommit
   include ActionView::Helpers::SanitizeHelper
 
   # Raised when given an invalid file path
@@ -9,21 +9,21 @@ class Projects::BlobController < Projects::ApplicationController
 
   before_action :require_non_empty_project, except: [:new, :create]
   before_action :authorize_download_code!
-  before_action :authorize_push_code!, only: [:destroy, :create]
+  before_action :authorize_edit_tree!, only: [:new, :create, :edit, :update, :destroy]
   before_action :assign_blob_vars
   before_action :commit, except: [:new, :create]
   before_action :blob, except: [:new, :create]
   before_action :from_merge_request, only: [:edit, :update]
   before_action :require_branch_head, only: [:edit, :update]
   before_action :editor_variables, except: [:show, :preview, :diff]
-  before_action :after_edit_path, only: [:edit, :update]
 
   def new
     commit unless @repository.empty?
   end
 
   def create
-    create_commit(Files::CreateService, success_path: after_create_path,
+    create_commit(Files::CreateService, success_notice: "The file has been successfully created.",
+                                        success_path: namespace_project_blob_path(@project.namespace, @project, File.join(@target_branch, @file_path)),
                                         failure_view: :new,
                                         failure_path: namespace_project_new_blob_path(@project.namespace, @project, @ref))
   end
@@ -36,6 +36,14 @@ class Projects::BlobController < Projects::ApplicationController
   end
 
   def update
+    after_edit_path =
+      if from_merge_request && @target_branch == @ref
+        diffs_namespace_project_merge_request_path(from_merge_request.target_project.namespace, from_merge_request.target_project, from_merge_request) +
+          "#file-path-#{hexdigest(@path)}"
+      else
+        namespace_project_blob_path(@project.namespace, @project, File.join(@target_branch, @path))
+      end
+
     create_commit(Files::UpdateService, success_path: after_edit_path,
                                         failure_view: :edit,
                                         failure_path: namespace_project_blob_path(@project.namespace, @project, @id))
@@ -50,15 +58,10 @@ class Projects::BlobController < Projects::ApplicationController
   end
 
   def destroy
-    result = Files::DeleteService.new(@project, current_user, @commit_params).execute
-
-    if result[:status] == :success
-      flash[:notice] = "Your changes have been successfully committed"
-      redirect_to after_destroy_path
-    else
-      flash[:alert] = result[:message]
-      render :show
-    end
+    create_commit(Files::DeleteService, success_notice: "The file has been successfully deleted.",
+                                        success_path: namespace_project_tree_path(@project.namespace, @project, @target_branch),
+                                        failure_view: :show,
+                                        failure_path: namespace_project_blob_path(@project.namespace, @project, @id))
   end
 
   def diff
@@ -108,74 +111,13 @@ class Projects::BlobController < Projects::ApplicationController
     render_404
   end
 
-  def create_commit(service, success_path:, failure_view:, failure_path:)
-    result = service.new(@project, current_user, @commit_params).execute
-
-    if result[:status] == :success
-      flash[:notice] = "Your changes have been successfully committed"
-      respond_to do |format|
-        format.html { redirect_to success_path }
-        format.json { render json: { message: "success", filePath: success_path } }
-      end
-    else
-      flash[:alert] = result[:message]
-      respond_to do |format|
-        format.html { render failure_view }
-        format.json { render json: { message: "failed", filePath: failure_path } }
-      end
-    end
-  end
-
-  def after_create_path
-    @after_create_path ||=
-      if create_merge_request?
-        new_merge_request_path
-      else
-        namespace_project_blob_path(@project.namespace, @project, File.join(@new_branch, @file_path))
-      end
-  end
-
-  def after_edit_path
-    @after_edit_path ||=
-      if create_merge_request?
-        new_merge_request_path
-      elsif from_merge_request && @new_branch == @ref
-        diffs_namespace_project_merge_request_path(from_merge_request.target_project.namespace, from_merge_request.target_project, from_merge_request) +
-          "#file-path-#{hexdigest(@path)}"
-      else
-        namespace_project_blob_path(@project.namespace, @project, File.join(@new_branch, @path))
-      end
-  end
-
-  def after_destroy_path
-    @after_destroy_path ||=
-      if create_merge_request?
-        new_merge_request_path
-      else
-        namespace_project_tree_path(@project.namespace, @project, @new_branch)
-      end
-  end
-
   def from_merge_request
     # If blob edit was initiated from merge request page
     @from_merge_request ||= MergeRequest.find_by(id: params[:from_merge_request_id])
   end
 
-  def sanitized_new_branch_name
-    sanitize(strip_tags(params[:new_branch]))
-  end
-
   def editor_variables
-    @current_branch = @ref
-
-    @new_branch =
-      if params[:new_branch].present?
-        sanitized_new_branch_name
-      elsif ::Gitlab::GitAccess.new(current_user, @project).can_push_to_branch?(@ref)
-        @ref
-      else
-        @repository.next_patch_branch
-      end
+    @target_branch = params[:target_branch]
 
     @file_path =
       if action_name.to_s == 'create'
@@ -194,8 +136,6 @@ class Projects::BlobController < Projects::ApplicationController
 
     @commit_params = {
       file_path: @file_path,
-      current_branch: @current_branch,
-      target_branch: @new_branch,
       commit_message: params[:commit_message],
       file_content: params[:content],
       file_content_encoding: params[:encoding]
diff --git a/app/controllers/projects/forks_controller.rb b/app/controllers/projects/forks_controller.rb
index 8a785076bb7be6e88c8b0f48de2214ddb48e9bb0..750181f0c1932257d9e60fa465578f986a070d31 100644
--- a/app/controllers/projects/forks_controller.rb
+++ b/app/controllers/projects/forks_controller.rb
@@ -10,19 +10,35 @@ class Projects::ForksController < Projects::ApplicationController
 
   def create
     namespace = Namespace.find(params[:namespace_key])
-    @forked_project = ::Projects::ForkService.new(project, current_user, namespace: namespace).execute
+    
+    @forked_project = namespace.projects.find_by(path: project.path)
+    @forked_project = nil unless @forked_project && @forked_project.forked_from_project == project
+
+    @forked_project ||= ::Projects::ForkService.new(project, current_user, namespace: namespace).execute
 
     if @forked_project.saved? && @forked_project.forked?
       if @forked_project.import_in_progress?
-        redirect_to namespace_project_import_path(@forked_project.namespace, @forked_project)
+        redirect_to namespace_project_import_path(@forked_project.namespace, @forked_project, continue: continue_params)
       else
-        redirect_to(
-          namespace_project_path(@forked_project.namespace, @forked_project),
-          notice: 'Project was successfully forked.'
-        )
+        if continue_params
+          redirect_to continue_params[:to], notice: continue_params[:notice]
+        else
+          redirect_to namespace_project_path(@forked_project.namespace, @forked_project), notice: "The project was successfully forked."
+        end
       end
     else
       render :error
     end
   end
+
+  private
+
+  def continue_params
+    continue_params = params[:continue]
+    if continue_params
+      continue_params.permit(:to, :notice, :notice_now)
+    else
+      nil
+    end
+  end
 end
diff --git a/app/controllers/projects/imports_controller.rb b/app/controllers/projects/imports_controller.rb
index fb8788f0818bbbd7d4b022b1dab647ec45035460..8d8035ef5ff9a993b161358a66f1f13e80016367 100644
--- a/app/controllers/projects/imports_controller.rb
+++ b/app/controllers/projects/imports_controller.rb
@@ -1,7 +1,7 @@
 class Projects::ImportsController < Projects::ApplicationController
   # Authorize
   before_action :authorize_admin_project!
-  before_action :require_no_repo
+  before_action :require_no_repo, except: :show
   before_action :redirect_if_progress, except: :show
 
   def new
@@ -24,21 +24,36 @@ class Projects::ImportsController < Projects::ApplicationController
   end
 
   def show
-    unless @project.import_in_progress?
-      if @project.import_finished?
-        redirect_to(project_path(@project)) and return
+    if @project.repository_exists? || @project.import_finished?
+      if continue_params
+        redirect_to continue_params[:to], notice: continue_params[:notice]
       else
-        redirect_to(new_namespace_project_import_path(@project.namespace,
-                                                      @project)) and return
+        redirect_to project_path(@project), notice: "The project was successfully forked."
       end
+    elsif @project.import_failed?
+      redirect_to new_namespace_project_import_path(@project.namespace, @project)
+    else
+      if continue_params && continue_params[:notice_now]
+        flash.now[:notice] = continue_params[:notice_now]
+      end
+      # Render
     end
   end
 
   private
 
+  def continue_params
+    continue_params = params[:continue]
+    if continue_params
+      continue_params.permit(:to, :notice, :notice_now)
+    else
+      nil
+    end
+  end
+
   def require_no_repo
     if @project.repository_exists? && !@project.import_in_progress?
-      redirect_to(namespace_project_path(@project.namespace, @project)) and return
+      redirect_to(namespace_project_path(@project.namespace, @project))
     end
   end
 
diff --git a/app/controllers/projects/notes_controller.rb b/app/controllers/projects/notes_controller.rb
index ee705f32e814b7994d01cf4971fac1cd3a90ec2a..6f1e186d4084d4eb4729a74b989785c48115ad6a 100644
--- a/app/controllers/projects/notes_controller.rb
+++ b/app/controllers/projects/notes_controller.rb
@@ -139,7 +139,6 @@ class Projects::NotesController < Projects::ApplicationController
         discussion_id: note.discussion_id,
         html: note_to_html(note),
         award: note.is_award,
-        emoji_path: note.is_award ? view_context.image_url(::AwardEmoji.path_to_emoji_image(note.note)) : "",
         note: note.note,
         discussion_html: note_to_discussion_html(note),
         discussion_with_diff_html: note_to_discussion_with_diff_html(note)
diff --git a/app/controllers/projects/services_controller.rb b/app/controllers/projects/services_controller.rb
index 6e7590260ff0e3bfa6f88fc706e54054b0b14c32..8b2577aebe1e537dc368cac0598bfc1154650c30 100644
--- a/app/controllers/projects/services_controller.rb
+++ b/app/controllers/projects/services_controller.rb
@@ -1,5 +1,5 @@
 class Projects::ServicesController < Projects::ApplicationController
-  ALLOWED_PARAMS = [:title, :token, :type, :active, :api_key, :api_version, :subdomain,
+  ALLOWED_PARAMS = [:title, :token, :type, :active, :api_key, :api_url, :api_version, :subdomain,
                     :room, :recipients, :project_url, :webhook,
                     :user_key, :device, :priority, :sound, :bamboo_url, :username, :password,
                     :build_key, :server, :teamcity_url, :drone_url, :build_type,
@@ -10,7 +10,8 @@ class Projects::ServicesController < Projects::ApplicationController
                     :notify_only_broken_builds, :add_pusher,
                     :send_from_committer_email, :disable_diffs, :external_wiki_url,
                     :notify, :color,
-                    :server_host, :server_port, :default_irc_uri, :enable_ssl_verification]
+                    :server_host, :server_port, :default_irc_uri, :enable_ssl_verification,
+                    :jira_issue_transition_id]
 
   # Parameters to ignore if no value is specified
   FILTER_BLANK_PARAMS = [:password]
diff --git a/app/controllers/projects/tree_controller.rb b/app/controllers/projects/tree_controller.rb
index 8f272ad1281fef7306c646248ff67acf1f18465d..cb3ed0f6f9c25dabfb05247f6002bf2478330a3d 100644
--- a/app/controllers/projects/tree_controller.rb
+++ b/app/controllers/projects/tree_controller.rb
@@ -1,14 +1,14 @@
 # Controller for viewing a repository's file structure
 class Projects::TreeController < Projects::ApplicationController
   include ExtractsPath
-  include CreatesMergeRequestForCommit
+  include CreatesCommit
   include ActionView::Helpers::SanitizeHelper
 
   before_action :require_non_empty_project, except: [:new, :create]
   before_action :assign_ref_vars
   before_action :assign_dir_vars, only: [:create_dir]
   before_action :authorize_download_code!
-  before_action :authorize_push_code!, only: [:create_dir]
+  before_action :authorize_edit_tree!, only: [:create_dir]
 
   def show
     return render_404 unless @repository.commit(@ref)
@@ -34,44 +34,20 @@ class Projects::TreeController < Projects::ApplicationController
   def create_dir
     return render_404 unless @commit_params.values.all?
 
-    begin
-      result = Files::CreateDirService.new(@project, current_user, @commit_params).execute
-      message = result[:message]
-    rescue => e
-      message = e.to_s
-    end
-
-    if result && result[:status] == :success
-      flash[:notice] = "The directory has been successfully created"
-      respond_to do |format|
-        format.html { redirect_to after_create_dir_path }
-      end
-    else
-      flash[:alert] = message
-      respond_to do |format|
-        format.html { redirect_to namespace_project_blob_path(@project.namespace, @project, @new_branch) }
-      end
-    end
+    create_commit(Files::CreateDirService,  success_notice: "The directory has been successfully created.",
+                                            success_path: namespace_project_tree_path(@project.namespace, @project, File.join(@target_branch, @dir_name)),
+                                            failure_path: namespace_project_tree_path(@project.namespace, @project, @ref))
   end
 
   private
 
   def assign_dir_vars
-    @new_branch = params[:new_branch].present? ? sanitize(strip_tags(params[:new_branch])) : @ref
+    @target_branch = params[:target_branch]
+
     @dir_name = File.join(@path, params[:dir_name])
     @commit_params = {
       file_path: @dir_name,
-      current_branch: @ref,
-      target_branch: @new_branch,
       commit_message: params[:commit_message],
     }
   end
-
-  def after_create_dir_path
-    if create_merge_request?
-      new_merge_request_path
-    else
-      namespace_project_blob_path(@project.namespace, @project, File.join(@new_branch, @dir_name))
-    end
-  end
 end
diff --git a/app/controllers/projects_controller.rb b/app/controllers/projects_controller.rb
index bf5e25ff89514d0da9e62bdc76aa1cdc392ab52a..2dab04f2a7c03aff18c49ebee4fe4734c09d3a54 100644
--- a/app/controllers/projects_controller.rb
+++ b/app/controllers/projects_controller.rb
@@ -171,7 +171,7 @@ class ProjectsController < ApplicationController
     @project.reload
 
     render json: {
-      html: view_to_html_string("projects/buttons/_star")
+      star_count: @project.star_count
     }
   end
 
diff --git a/app/helpers/blob_helper.rb b/app/helpers/blob_helper.rb
index 68e5d5be600edcff277409109b8a7c020bcdcea7..d31d4cde08f4dcb2579d2fd582c50111401e9bca 100644
--- a/app/helpers/blob_helper.rb
+++ b/app/helpers/blob_helper.rb
@@ -22,32 +22,90 @@ module BlobHelper
     %w(credits changelog news copying copyright license authors)
   end
 
-  def edit_blob_link(project, ref, path, options = {})
-    blob =
-      begin
-        project.repository.blob_at(ref, path)
-      rescue
-        nil
-      end
-
-    return unless blob && blob.text? && blob_editable?(blob)
-
-    text = 'Edit'
-    after = options[:after] || ''
+  def edit_blob_link(project = @project, ref = @ref, path = @path, options = {})
+    return unless current_user
+
+    blob = project.repository.blob_at(ref, path) rescue nil
+
+    return unless blob && blob_text_viewable?(blob)
+
     from_mr = options[:from_merge_request_id]
     link_opts = {}
     link_opts[:from_merge_request_id] = from_mr if from_mr
-    cls = 'btn btn-small'
-    link_to(text,
-            namespace_project_edit_blob_path(project.namespace, project,
-                                             tree_join(ref, path),
-                                             link_opts),
-            class: cls
-           ) + after.html_safe
+
+    edit_path = namespace_project_edit_blob_path(project.namespace, project,
+                                     tree_join(ref, path),
+                                     link_opts)
+
+    if !on_top_of_branch?
+      button_tag "Edit", class: "btn btn-default disabled has_tooltip", title: "You can only edit files when you are on a branch", data: { container: 'body' }
+    elsif can_edit_blob?(blob)
+      link_to "Edit", edit_path, class: 'btn btn-small'
+    elsif can?(current_user, :fork_project, project)
+      continue_params = {
+        to:     edit_path,
+        notice: edit_in_new_fork_notice,
+        notice_now: edit_in_new_fork_notice_now
+      }
+      fork_path = namespace_project_fork_path(project.namespace, project, namespace_key:  current_user.namespace.id,
+                                                                          continue:       continue_params)
+
+      link_to "Edit", fork_path, class: 'btn btn-small', method: :post
+    end
+  end
+
+  def modify_file_link(project = @project, ref = @ref, path = @path, label:, action:, btn_class:, modal_type:)
+    return unless current_user
+
+    blob = project.repository.blob_at(ref, path) rescue nil
+
+    return unless blob
+
+    if !on_top_of_branch?
+      button_tag label, class: "btn btn-#{btn_class} disabled has_tooltip", title: "You can only #{action} files when you are on a branch", data: { container: 'body' }
+    elsif blob.lfs_pointer?
+      button_tag label, class: "btn btn-#{btn_class} disabled has_tooltip", title: "It is not possible to #{action} files that are stored in LFS using the web interface", data: { container: 'body' }
+    elsif can_edit_blob?(blob)
+      button_tag label, class: "btn btn-#{btn_class}", 'data-target' => "#modal-#{modal_type}-blob", 'data-toggle' => 'modal'
+    elsif can?(current_user, :fork_project, project)
+      continue_params = {
+        to:     request.fullpath,
+        notice: edit_in_new_fork_notice + " Try to #{action} this file again.",
+        notice_now: edit_in_new_fork_notice_now
+      }
+      fork_path = namespace_project_fork_path(project.namespace, project, namespace_key:  current_user.namespace.id,
+                                                                          continue:       continue_params)
+
+      link_to label, fork_path, class: "btn btn-#{btn_class}", method: :post
+    end
+  end
+
+  def replace_blob_link(project = @project, ref = @ref, path = @path)
+    modify_file_link(
+      project,
+      ref,
+      path,
+      label:      "Replace",
+      action:     "replace",
+      btn_class:  "default",
+      modal_type: "upload"
+    )
+  end
+
+  def delete_blob_link(project = @project, ref = @ref, path = @path)
+    modify_file_link(
+      project,
+      ref,
+      path,
+      label:      "Delete",
+      action:     "delete",
+      btn_class:  "remove",
+      modal_type: "remove"
+    )
   end
 
-  def blob_editable?(blob, project = @project, ref = @ref)
-    !blob.lfs_pointer? && allowed_tree_edit?(project, ref)
+  def can_edit_blob?(blob, project = @project, ref = @ref)
+    !blob.lfs_pointer? && can_edit_tree?(project, ref)
   end
 
   def leave_edit_message
@@ -70,7 +128,7 @@ module BlobHelper
     icon("#{file_type_icon_class('file', mode, name)} fw")
   end
 
-  def blob_viewable?(blob)
+  def blob_text_viewable?(blob)
     blob && blob.text? && !blob.lfs_pointer?
   end
 
diff --git a/app/helpers/issues_helper.rb b/app/helpers/issues_helper.rb
index d2186427dba03e68d76ff45c225f576ad232a9c3..4fe843221996eec9c40c5b342d50b5ebfb355199 100644
--- a/app/helpers/issues_helper.rb
+++ b/app/helpers/issues_helper.rb
@@ -94,11 +94,14 @@ module IssuesHelper
     end.sort.to_sentence(last_word_connector: ', or ')
   end
 
-  def url_to_emoji(name)
-    emoji_path = ::AwardEmoji.path_to_emoji_image(name)
-    url_to_image(emoji_path)
-  rescue StandardError
-    ""
+  def emoji_icon(name, unicode = nil, aliases = [])
+    unicode ||= Emoji.emoji_filename(name)
+
+    content_tag :div, "",
+      class: "icon emoji-icon emoji-#{unicode}",
+      "data-emoji" => name,
+      "data-aliases" => aliases.join(" "),
+      "data-unicode-name" => unicode
   end
 
   def emoji_author_list(notes, current_user)
@@ -109,10 +112,6 @@ module IssuesHelper
     list.join(", ")
   end
 
-  def emoji_list
-    ::AwardEmoji::EMOJI_LIST
-  end
-
   def note_active_class(notes, current_user)
     if current_user && notes.pluck(:author_id).include?(current_user.id)
       "active"
diff --git a/app/helpers/merge_requests_helper.rb b/app/helpers/merge_requests_helper.rb
index 6c32647594d5a0642d70f52ed57cb93b5989badb..1dd07a2a2204b0368671f57e3b89b05b82432477 100644
--- a/app/helpers/merge_requests_helper.rb
+++ b/app/helpers/merge_requests_helper.rb
@@ -27,7 +27,16 @@ module MergeRequestsHelper
   end
 
   def ci_build_details_path(merge_request)
-    merge_request.source_project.ci_service.build_page(merge_request.last_commit.sha, merge_request.source_branch)
+    build_url = merge_request.source_project.ci_service.build_page(merge_request.last_commit.sha, merge_request.source_branch)
+    return nil unless build_url
+
+    parsed_url = URI.parse(build_url)
+
+    unless parsed_url.userinfo.blank?
+      parsed_url.userinfo = ''
+    end
+
+    parsed_url.to_s
   end
 
   def merge_path_description(merge_request, separator)
diff --git a/app/helpers/projects_helper.rb b/app/helpers/projects_helper.rb
index 777817e24aa0f7615b08cde7adec1616d3aad86c..77ba612548a11785dbb214bbd2e8026e9c879946 100644
--- a/app/helpers/projects_helper.rb
+++ b/app/helpers/projects_helper.rb
@@ -105,6 +105,14 @@ module ProjectsHelper
     end
   end
 
+  def user_max_access_in_project(user_id, project)
+    level = project.team.max_member_access(user_id)
+
+    if level
+      Gitlab::Access.options_with_owner.key(level)
+    end
+  end
+
   private
 
   def get_project_nav_tabs(project, current_user)
@@ -277,14 +285,6 @@ module ProjectsHelper
     end
   end
 
-  def user_max_access_in_project(user, project)
-    level = project.team.max_member_access(user)
-
-    if level
-      Gitlab::Access.options_with_owner.key(level)
-    end
-  end
-
   def leave_project_message(project)
     "Are you sure you want to leave \"#{project.name}\" project?"
   end
diff --git a/app/helpers/tree_helper.rb b/app/helpers/tree_helper.rb
index f448dd0ab61fd863cf47b7e61f7b2a3b0ccb95ff..2ad7c80dae0fe5379a9f074f3fcdf6a816e128f5 100644
--- a/app/helpers/tree_helper.rb
+++ b/app/helpers/tree_helper.rb
@@ -50,24 +50,49 @@ module TreeHelper
     project.repository.branch_names.include?(ref)
   end
 
-  def allowed_tree_edit?(project = nil, ref = nil)
+  def can_edit_tree?(project = nil, ref = nil)
     project ||= @project
     ref ||= @ref
+
     return false unless on_top_of_branch?(project, ref)
 
-    can?(current_user, :push_code, project)
+    can?(current_user, :push_code, project) ||
+      (current_user && current_user.already_forked?(project))
   end
 
   def tree_edit_branch(project = @project, ref = @ref)
-    if allowed_tree_edit?(project, ref)
-      if can_push_branch?(project, ref)
-        ref
-      else
-        project.repository.next_patch_branch
-      end
+    return unless can_edit_tree?(project, ref)
+
+    if can_push_branch?(project, ref)
+      ref
+    else
+      project = tree_edit_project(project)
+      project.repository.next_patch_branch
+    end
+  end
+
+  def tree_edit_project(project = @project)
+    if can?(current_user, :push_code, project)
+      project
+    elsif current_user && current_user.already_forked?(project)
+      current_user.fork_of(project)
     end
   end
 
+  def edit_in_new_fork_notice_now
+    "You're not allowed to make changes to this project directly." +
+      " A fork of this project is being created that you can make changes in, so you can submit a merge request."
+  end
+
+  def edit_in_new_fork_notice
+    "You're not allowed to make changes to this project directly." +
+      " A fork of this project has been created that you can make changes in, so you can submit a merge request."
+  end
+
+  def commit_in_fork_help
+    "A new branch will be created in your fork and a new merge request will be started."
+  end
+
   def tree_breadcrumbs(tree, max_links = 2)
     if @path.present?
       part_path = ""
diff --git a/app/helpers/visibility_level_helper.rb b/app/helpers/visibility_level_helper.rb
index 2e69ce923a2f9438e8fc788be8447b28f72ce838..71d33b445c22bea272c664e004ef0f01401ea4db 100644
--- a/app/helpers/visibility_level_helper.rb
+++ b/app/helpers/visibility_level_helper.rb
@@ -69,7 +69,6 @@ module VisibilityLevelHelper
 
   def skip_level?(form_model, level)
     form_model.is_a?(Project) &&
-    form_model.forked? &&
-    !Gitlab::VisibilityLevel.allowed_fork_levels(form_model.forked_from_project.visibility_level).include?(level)
+    !form_model.visibility_level_allowed?(level)
   end
 end
diff --git a/app/models/ability.rb b/app/models/ability.rb
index cd5ae0fb0fd3c99182320d605c7e24bc5904a2b9..1b3ee757040515250134b79afe752fc30883f16a 100644
--- a/app/models/ability.rb
+++ b/app/models/ability.rb
@@ -132,14 +132,14 @@ class Ability
     end
 
     def public_project_rules
-      project_guest_rules + [
+      @public_project_rules ||= project_guest_rules + [
         :download_code,
         :fork_project
       ]
     end
 
     def project_guest_rules
-      [
+      @project_guest_rules ||= [
         :read_project,
         :read_wiki,
         :read_issue,
@@ -157,7 +157,7 @@ class Ability
     end
 
     def project_report_rules
-      project_guest_rules + [
+      @project_report_rules ||= project_guest_rules + [
         :create_commit_status,
         :read_commit_statuses,
         :download_code,
@@ -170,7 +170,7 @@ class Ability
     end
 
     def project_dev_rules
-      project_report_rules + [
+      @project_dev_rules ||= project_report_rules + [
         :admin_merge_request,
         :create_merge_request,
         :create_wiki,
@@ -181,7 +181,7 @@ class Ability
     end
 
     def project_archived_rules
-      [
+      @project_archived_rules ||= [
         :create_merge_request,
         :push_code,
         :push_code_to_protected_branches,
@@ -191,7 +191,7 @@ class Ability
     end
 
     def project_master_rules
-      project_dev_rules + [
+      @project_master_rules ||= project_dev_rules + [
         :push_code_to_protected_branches,
         :update_project_snippet,
         :update_merge_request,
@@ -206,7 +206,7 @@ class Ability
     end
 
     def project_admin_rules
-      project_master_rules + [
+      @project_admin_rules ||= project_master_rules + [
         :change_namespace,
         :change_visibility_level,
         :rename_project,
@@ -332,7 +332,7 @@ class Ability
       end
 
       if snippet.public? || snippet.internal?
-        rules << :read_personal_snippet 
+        rules << :read_personal_snippet
       end
 
       rules
diff --git a/app/models/application_setting.rb b/app/models/application_setting.rb
index 1f4e8b3ef24c8d4dddc370fa0a5edf6fc4fdf585..724429e755855737ed3c66b75f5224e8f2fa0425 100644
--- a/app/models/application_setting.rb
+++ b/app/models/application_setting.rb
@@ -134,4 +134,8 @@ class ApplicationSetting < ActiveRecord::Base
       /x)
     self.restricted_signup_domains.reject! { |d| d.empty? }
   end
+
+  def runners_registration_token
+    ensure_runners_registration_token!
+  end
 end
diff --git a/app/models/ci/build.rb b/app/models/ci/build.rb
index 6d9cdb95295d395186ab3b6e5597b4bad8e08d79..7b89fe069ea158061ee29c98d3f0c2fcc2e13c84 100644
--- a/app/models/ci/build.rb
+++ b/app/models/ci/build.rb
@@ -135,6 +135,16 @@ module Ci
       predefined_variables + yaml_variables + project_variables + trigger_variables
     end
 
+    def merge_request
+      merge_requests = MergeRequest.includes(:merge_request_diff)
+                                   .where(source_branch: ref, source_project_id: commit.gl_project_id)
+                                   .reorder(iid: :asc)
+
+      merge_requests.find do |merge_request|
+        merge_request.commits.any? { |ci| ci.id == commit.sha }
+      end
+    end
+
     def project
       commit.project
     end
@@ -170,7 +180,8 @@ module Ci
 
     def extract_coverage(text, regex)
       begin
-        matches = text.gsub(Regexp.new(regex)).to_a.last
+        matches = text.scan(Regexp.new(regex)).last
+        matches = matches.last if matches.kind_of?(Array)
         coverage = matches.gsub(/\d+(\.\d+)?/).first
 
         if coverage.present?
diff --git a/app/models/concerns/participable.rb b/app/models/concerns/participable.rb
index 808d80b0530fb417885ae5cf2524d77bbd0c09bc..fc6f83b918b4929240bd85acfb9906af1ea51b1a 100644
--- a/app/models/concerns/participable.rb
+++ b/app/models/concerns/participable.rb
@@ -37,7 +37,7 @@ module Participable
 
   # Be aware that this method makes a lot of sql queries.
   # Save result into variable if you are going to reuse it inside same request
-  def participants(current_user = self.author, load_lazy_references: true)
+  def participants(current_user = self.author)
     participants =
       Gitlab::ReferenceExtractor.lazily do
         self.class.participant_attrs.flat_map do |attr|
diff --git a/app/models/concerns/token_authenticatable.rb b/app/models/concerns/token_authenticatable.rb
index 488ff8c31b7d9e23f1a0232269c6ef518967fa92..885deaf78d2d480b0ad416a04f0d3a970ed45833 100644
--- a/app/models/concerns/token_authenticatable.rb
+++ b/app/models/concerns/token_authenticatable.rb
@@ -18,15 +18,16 @@ module TokenAuthenticatable
 
       define_method("ensure_#{token_field}") do
         current_token = read_attribute(token_field)
-        if current_token.blank?
-          write_attribute(token_field, generate_token_for(token_field))
-        else
-          current_token
-        end
+        current_token.blank? ? write_new_token(token_field) : current_token
+      end
+
+      define_method("ensure_#{token_field}!") do
+        send("reset_#{token_field}!") if read_attribute(token_field).blank?
+        read_attribute(token_field)
       end
 
       define_method("reset_#{token_field}!") do
-        write_attribute(token_field, generate_token_for(token_field))
+        write_new_token(token_field)
         save!
       end
     end
@@ -34,7 +35,12 @@ module TokenAuthenticatable
 
   private
 
-  def generate_token_for(token_field)
+  def write_new_token(token_field)
+    new_token = generate_token(token_field)
+    write_attribute(token_field, new_token)
+  end
+
+  def generate_token(token_field)
     loop do
       token = Devise.friendly_token
       break token unless self.class.unscoped.find_by(token_field => token)
diff --git a/app/models/global_milestone.rb b/app/models/global_milestone.rb
index 8bfc79d88f8d1ad82027123a7f9413ba5ecb3df9..af1d7562ebe2a5312fdcf1e477a1af0812952e4f 100644
--- a/app/models/global_milestone.rb
+++ b/app/models/global_milestone.rb
@@ -16,7 +16,7 @@ class GlobalMilestone
   end
 
   def safe_title
-    @title.to_slug.to_s
+    @title.to_slug.normalize.to_s
   end
 
   def expired?
diff --git a/app/models/identity.rb b/app/models/identity.rb
index ad60154be710f0af8092db93d76b28ad765b5f69..8bcdc1949538f9dc67a1de39223f20fc7d68f57f 100644
--- a/app/models/identity.rb
+++ b/app/models/identity.rb
@@ -12,6 +12,7 @@
 
 class Identity < ActiveRecord::Base
   include Sortable
+  include CaseSensitivity
   belongs_to :user
 
   validates :provider, presence: true
diff --git a/app/models/issue.rb b/app/models/issue.rb
index 4571d7f0ee10bed4688e06811318984dd779fa6f..80ecd15077f188864ad3719fa8bb223492cc5b58 100644
--- a/app/models/issue.rb
+++ b/app/models/issue.rb
@@ -86,7 +86,7 @@ class Issue < ActiveRecord::Base
   def referenced_merge_requests
     Gitlab::ReferenceExtractor.lazily do
       [self, *notes].flat_map do |note|
-        note.all_references(load_lazy_references: false).merge_requests
+        note.all_references.merge_requests
       end
     end.sort_by(&:iid)
   end
diff --git a/app/models/jira_issue.rb b/app/models/jira_issue.rb
new file mode 100644
index 0000000000000000000000000000000000000000..5b21aac5e43c5902e67e0ed1af87aa155ae9fcce
--- /dev/null
+++ b/app/models/jira_issue.rb
@@ -0,0 +1,2 @@
+class JiraIssue < ExternalIssue
+end
diff --git a/app/models/merge_request.rb b/app/models/merge_request.rb
index d7430d36c41c53a3ac62253ca0a065e656ad396a..ac25d38eb6338be998c93c6711e54c806df77a47 100644
--- a/app/models/merge_request.rb
+++ b/app/models/merge_request.rb
@@ -335,7 +335,7 @@ class MergeRequest < ActiveRecord::Base
       issues = commits.flat_map { |c| c.closes_issues(current_user) }
       issues.push(*Gitlab::ClosingIssueExtractor.new(project, current_user).
                   closed_by_message(description))
-      issues.uniq
+      issues.uniq(&:id)
     else
       []
     end
diff --git a/app/models/project.rb b/app/models/project.rb
index 13fd383237c7684ad124708c44282c76e422de56..75f85310d5f24c465a3ba28d0cf46d3226cb8deb 100644
--- a/app/models/project.rb
+++ b/app/models/project.rb
@@ -64,6 +64,19 @@ class Project < ActiveRecord::Base
     update_column(:last_activity_at, self.created_at)
   end
 
+  # update visibility_levet of forks
+  after_update :update_forks_visibility_level
+  def update_forks_visibility_level
+    return unless visibility_level < visibility_level_was
+
+    forks.each do |forked_project|
+      if forked_project.visibility_level > visibility_level
+        forked_project.visibility_level = visibility_level
+        forked_project.save!
+      end
+    end
+  end
+
   ActsAsTaggableOn.strict_case_match = true
   acts_as_taggable_on :tags
 
@@ -100,9 +113,12 @@ class Project < ActiveRecord::Base
   has_one :gitlab_issue_tracker_service, dependent: :destroy
   has_one :external_wiki_service, dependent: :destroy
 
-  has_one :forked_project_link, dependent: :destroy, foreign_key: "forked_to_project_id"
+  has_one  :forked_project_link,  dependent: :destroy, foreign_key: "forked_to_project_id"
+  has_one  :forked_from_project,  through:   :forked_project_link
+
+  has_many :forked_project_links, foreign_key: "forked_from_project_id"
+  has_many :forks,                through:     :forked_project_links, source: :forked_to_project
 
-  has_one :forked_from_project, through: :forked_project_link
   # Merge Requests for target project should be removed with it
   has_many :merge_requests,     dependent: :destroy, foreign_key: 'target_project_id'
   # Merge requests from source project should be kept when source project was removed
@@ -499,6 +515,10 @@ class Project < ActiveRecord::Base
     @ci_service ||= ci_services.find(&:activated?)
   end
 
+  def jira_tracker?
+    issues_tracker.to_param == 'jira'
+  end
+
   def avatar_type
     unless self.avatar.image?
       self.errors.add :avatar, 'only images allowed'
@@ -764,7 +784,7 @@ class Project < ActiveRecord::Base
   end
 
   def forks_count
-    ForkedProjectLink.where(forked_from_project_id: self.id).count
+    forks.count
   end
 
   def find_label(name)
@@ -799,6 +819,10 @@ class Project < ActiveRecord::Base
     false
   end
 
+  def jira_tracker_active?
+    jira_tracker? && jira_service.active
+  end
+
   def ci_commit(sha)
     ci_commits.find_by(sha: sha)
   end
@@ -854,4 +878,9 @@ class Project < ActiveRecord::Base
   def open_issues_count
     issues.opened.count
   end
+
+  def visibility_level_allowed?(level)
+    return true unless forked?
+    Gitlab::VisibilityLevel.allowed_fork_levels(forked_from_project.visibility_level).include?(level.to_i)
+  end
 end
diff --git a/app/models/project_services/gitlab_ci_service.rb b/app/models/project_services/gitlab_ci_service.rb
index d73182d40ac6235cee37728b063bf8365a4247f4..b64d97ce75dc5d2ebd90f410812b527c88a6d11d 100644
--- a/app/models/project_services/gitlab_ci_service.rb
+++ b/app/models/project_services/gitlab_ci_service.rb
@@ -18,6 +18,11 @@
 #  note_events           :boolean          default(TRUE), not null
 #
 
+# TODO(ayufan): The GitLabCiService is deprecated and the type should be removed when the database entries are removed
 class GitlabCiService < CiService
-  # this is no longer used
+  # We override the active accessor to always make GitLabCiService disabled
+  # Otherwise the GitLabCiService can be picked, but should never be since it's deprecated
+  def active
+    false
+  end
 end
diff --git a/app/models/project_services/jira_service.rb b/app/models/project_services/jira_service.rb
index 35e30b1cb0b76370baa3d5c714afbde0f2269209..e216f406e1cb672187d8dadfd2f91a375b878143 100644
--- a/app/models/project_services/jira_service.rb
+++ b/app/models/project_services/jira_service.rb
@@ -19,9 +19,24 @@
 #
 
 class JiraService < IssueTrackerService
+  include HTTParty
   include Gitlab::Application.routes.url_helpers
 
-  prop_accessor :title, :description, :project_url, :issues_url, :new_issue_url
+  DEFAULT_API_VERSION = 2
+
+  prop_accessor :username, :password, :api_url, :jira_issue_transition_id,
+                :title, :description, :project_url, :issues_url, :new_issue_url
+
+  before_validation :set_api_url, :set_jira_issue_transition_id
+
+  before_update :reset_password
+
+  def reset_password
+    # don't reset the password if a new one is provided
+    if api_url_changed? && !password_touched?
+      self.password = nil
+    end
+  end
 
   def help
     line1 = 'Setting `project_url`, `issues_url` and `new_issue_url` will '\
@@ -54,4 +69,228 @@ class JiraService < IssueTrackerService
   def to_param
     'jira'
   end
+
+  def fields
+    super.push(
+      { type: 'text', name: 'api_url', placeholder: 'https://jira.example.com/rest/api/2' },
+      { type: 'text', name: 'username', placeholder: '' },
+      { type: 'password', name: 'password', placeholder: '' },
+      { type: 'text', name: 'jira_issue_transition_id', placeholder: '2' }
+    )
+  end
+
+  def execute(push, issue = nil)
+    if issue.nil?
+      # No specific issue, that means
+      # we just want to test settings
+      test_settings
+    else
+      close_issue(push, issue)
+    end
+  end
+
+  def create_cross_reference_note(mentioned, noteable, author)
+    issue_name = mentioned.id
+    project = self.project
+    noteable_name = noteable.class.name.underscore.downcase
+    noteable_id = if noteable.is_a?(Commit)
+                    noteable.id
+                  else
+                    noteable.iid
+                  end
+
+    entity_url = build_entity_url(noteable_name.to_sym, noteable_id)
+
+    data = {
+      user: {
+        name: author.name,
+        url: resource_url(user_path(author)),
+      },
+      project: {
+        name: project.path_with_namespace,
+        url: resource_url(namespace_project_path(project.namespace, project))
+      },
+      entity: {
+        name: noteable_name.humanize.downcase,
+        url: entity_url
+      }
+    }
+
+    add_comment(data, issue_name)
+  end
+
+  def test_settings
+    result = JiraService.get(
+      jira_api_test_url,
+      headers: {
+        'Content-Type' => 'application/json',
+        'Authorization' => "Basic #{auth}"
+      }
+    )
+
+    case result.code
+    when 201, 200
+      Rails.logger.info("#{self.class.name} SUCCESS #{result.code}: Successfully connected to #{api_url}.")
+      true
+    else
+      Rails.logger.info("#{self.class.name} ERROR #{result.code}: #{result.parsed_response}")
+      false
+    end
+  rescue Errno::ECONNREFUSED => e
+    Rails.logger.info "#{self.class.name} ERROR: #{e.message}. API URL: #{api_url}."
+    false
+  end
+
+  private
+
+  def build_api_url_from_project_url
+    server = URI(project_url)
+    default_ports = [["http",80],["https",443]].include?([server.scheme,server.port])
+    server_url = "#{server.scheme}://#{server.host}"
+    server_url.concat(":#{server.port}") unless default_ports
+    "#{server_url}/rest/api/#{DEFAULT_API_VERSION}"
+  rescue
+    "" # looks like project URL was not valid
+  end
+
+  def set_api_url
+    self.api_url = build_api_url_from_project_url if self.api_url.blank?
+  end
+
+  def set_jira_issue_transition_id
+    self.jira_issue_transition_id ||= "2"
+  end
+
+  def close_issue(entity, issue)
+    commit_id = if entity.is_a?(Commit)
+                  entity.id
+                elsif entity.is_a?(MergeRequest)
+                  entity.last_commit.id
+                end
+    commit_url = build_entity_url(:commit, commit_id)
+
+    # Depending on the JIRA project's workflow, a comment during transition
+    # may or may not be allowed. Split the operation in to two calls so the
+    # comment always works.
+    transition_issue(issue)
+    add_issue_solved_comment(issue, commit_id, commit_url)
+  end
+
+  def transition_issue(issue)
+    message = {
+      transition: {
+        id: jira_issue_transition_id
+      }
+    }
+    send_message(close_issue_url(issue.iid), message.to_json)
+  end
+
+  def add_issue_solved_comment(issue, commit_id, commit_url)
+    comment = {
+      body: "Issue solved with [#{commit_id}|#{commit_url}]."
+    }
+
+    send_message(comment_url(issue.iid), comment.to_json)
+  end
+
+  def add_comment(data, issue_name)
+    url = comment_url(issue_name)
+    user_name = data[:user][:name]
+    user_url = data[:user][:url]
+    entity_name = data[:entity][:name]
+    entity_url = data[:entity][:url]
+    project_name = data[:project][:name]
+
+    message = {
+      body: "[#{user_name}|#{user_url}] mentioned this issue in [a #{entity_name} of #{project_name}|#{entity_url}]."
+    }
+
+    unless existing_comment?(issue_name, message[:body])
+      send_message(url, message.to_json)
+    end
+  end
+
+
+  def auth
+    require 'base64'
+    Base64.urlsafe_encode64("#{self.username}:#{self.password}")
+  end
+
+  def send_message(url, message)
+    result = JiraService.post(
+      url,
+      body: message,
+      headers: {
+        'Content-Type' => 'application/json',
+        'Authorization' => "Basic #{auth}"
+      }
+    )
+
+    message = case result.code
+              when 201, 200, 204
+                "#{self.class.name} SUCCESS #{result.code}: Successfully posted to #{url}."
+              when 401
+                "#{self.class.name} ERROR 401: Unauthorized. Check the #{self.username} credentials and JIRA access permissions and try again."
+              else
+                "#{self.class.name} ERROR #{result.code}: #{result.parsed_response}"
+              end
+
+    Rails.logger.info(message)
+    message
+  rescue URI::InvalidURIError, Errno::ECONNREFUSED => e
+    Rails.logger.info "#{self.class.name} ERROR: #{e.message}. Hostname: #{url}."
+  end
+
+  def existing_comment?(issue_name, new_comment)
+    result = JiraService.get(
+      comment_url(issue_name),
+      headers: {
+        'Content-Type' => 'application/json',
+        'Authorization' => "Basic #{auth}"
+      }
+    )
+
+    case result.code
+    when 201, 200
+      existing_comments = JSON.parse(result.body)['comments']
+
+      if existing_comments.present?
+        return existing_comments.map { |comment| comment['body'].include?(new_comment) }.any?
+      end
+    end
+
+    false
+  rescue JSON::ParserError
+    false
+  end
+
+  def resource_url(resource)
+    "#{Settings.gitlab['url'].chomp("/")}#{resource}"
+  end
+
+  def build_entity_url(entity_name, entity_id)
+    resource_url(
+      polymorphic_url(
+        [
+          self.project.namespace.becomes(Namespace),
+          self.project,
+          entity_name
+        ],
+        id: entity_id,
+        routing_type: :path
+      )
+    )
+  end
+
+  def close_issue_url(issue_name)
+    "#{self.api_url}/issue/#{issue_name}/transitions"
+  end
+
+  def comment_url(issue_name)
+    "#{self.api_url}/issue/#{issue_name}/comment"
+  end
+
+  def jira_api_test_url
+    "#{self.api_url}/myself"
+  end
 end
diff --git a/app/models/repository.rb b/app/models/repository.rb
index 2c25f4ce451561a71301ccdcf952b535aa32a9d6..9f688e3b45bdd6e73aeb0e92790d190e8f0b775e 100644
--- a/app/models/repository.rb
+++ b/app/models/repository.rb
@@ -592,47 +592,54 @@ class Repository
     Gitlab::Popen.popen(args, path_to_repo)
   end
 
-  def commit_with_hooks(current_user, branch)
-    oldrev = Gitlab::Git::BLANK_SHA
-    ref = Gitlab::Git::BRANCH_REF_PREFIX + branch
-    was_empty = empty?
-
-    # Create temporary ref
+  def with_tmp_ref(oldrev = nil)
     random_string = SecureRandom.hex
     tmp_ref = "refs/tmp/#{random_string}/head"
 
-    unless was_empty
-      oldrev = find_branch(branch).target
+    if oldrev && !Gitlab::Git.blank_ref?(oldrev)
       rugged.references.create(tmp_ref, oldrev)
     end
 
     # Make commit in tmp ref
-    newrev = yield(tmp_ref)
+    yield(tmp_ref)
+  ensure
+    rugged.references.delete(tmp_ref) rescue nil
+  end
+
+  def commit_with_hooks(current_user, branch)
+    oldrev = Gitlab::Git::BLANK_SHA
+    ref = Gitlab::Git::BRANCH_REF_PREFIX + branch
+    was_empty = empty?
 
-    unless newrev
-      raise CommitError.new('Failed to create commit')
+    unless was_empty
+      oldrev = find_branch(branch).target
     end
 
-    GitHooksService.new.execute(current_user, path_to_repo, oldrev, newrev, ref) do
-      if was_empty
-        # Create branch
-        rugged.references.create(ref, newrev)
-      else
-        # Update head
-        current_head = find_branch(branch).target
+    with_tmp_ref(oldrev) do |tmp_ref|
+      # Make commit in tmp ref
+      newrev = yield(tmp_ref)
+
+      unless newrev
+        raise CommitError.new('Failed to create commit')
+      end
 
-        # Make sure target branch was not changed during pre-receive hook
-        if current_head == oldrev
-          rugged.references.update(ref, newrev)
+      GitHooksService.new.execute(current_user, path_to_repo, oldrev, newrev, ref) do
+        if was_empty
+          # Create branch
+          rugged.references.create(ref, newrev)
         else
-          raise CommitError.new('Commit was rejected because branch received new push')
+          # Update head
+          current_head = find_branch(branch).target
+
+          # Make sure target branch was not changed during pre-receive hook
+          if current_head == oldrev
+            rugged.references.update(ref, newrev)
+          else
+            raise CommitError.new('Commit was rejected because branch received new push')
+          end
         end
       end
     end
-  rescue GitHooksService::PreReceiveError
-    # Remove tmp ref and return error to user
-    rugged.references.delete(tmp_ref)
-    raise
   end
 
   private
diff --git a/app/models/user.rb b/app/models/user.rb
index e0ce091c54ebf06a1687294ada0ab67d8453cd60..df87f3b79bd66735c96a65eda8298d1c7fabcfe5 100644
--- a/app/models/user.rb
+++ b/app/models/user.rb
@@ -26,6 +26,7 @@
 #  bio                        :string(255)
 #  failed_attempts            :integer          default(0)
 #  locked_at                  :datetime
+#  unlock_token               :string(255)
 #  username                   :string(255)
 #  can_create_group           :boolean          default(TRUE), not null
 #  can_create_team            :boolean          default(TRUE), not null
diff --git a/app/services/base_service.rb b/app/services/base_service.rb
index f00ec7408b683fb6f00e6c85c38ad04364bfeef3..b48ca67d4d2de1c561aedb04c307b42cdabc7903 100644
--- a/app/services/base_service.rb
+++ b/app/services/base_service.rb
@@ -39,10 +39,7 @@ class BaseService
   def deny_visibility_level(model, denied_visibility_level = nil)
     denied_visibility_level ||= model.visibility_level
 
-    level_name = 'Unknown'
-    Gitlab::VisibilityLevel.options.each do |name, level|
-      level_name = name if level == denied_visibility_level
-    end
+    level_name = Gitlab::VisibilityLevel.level_name(denied_visibility_level)
 
     model.errors.add(
       :visibility_level,
diff --git a/app/services/create_branch_service.rb b/app/services/create_branch_service.rb
index de18f3bc5567f6c2194340fc3ed26dd76c3fe9e8..f139872c728ec618300c9a354ff6dffa5a176d85 100644
--- a/app/services/create_branch_service.rb
+++ b/app/services/create_branch_service.rb
@@ -1,10 +1,10 @@
 require_relative 'base_service'
 
 class CreateBranchService < BaseService
-  def execute(branch_name, ref)
+  def execute(branch_name, ref, source_project: @project)
     valid_branch = Gitlab::GitRefValidator.validate(branch_name)
     if valid_branch == false
-      return error('Branch name invalid')
+      return error('Branch name is invalid')
     end
 
     repository = project.repository
@@ -13,7 +13,20 @@ class CreateBranchService < BaseService
       return error('Branch already exists')
     end
 
-    new_branch = repository.add_branch(current_user, branch_name, ref)
+    new_branch = nil
+    if source_project != @project
+      repository.with_tmp_ref do |tmp_ref|
+        repository.fetch_ref(
+          source_project.repository.path_to_repo,
+          "refs/heads/#{ref}",
+          tmp_ref
+        )
+
+        new_branch = repository.add_branch(current_user, branch_name, tmp_ref)
+      end
+    else
+      new_branch = repository.add_branch(current_user, branch_name, ref)
+    end
 
     if new_branch
       push_data = build_push_data(project, current_user, new_branch)
diff --git a/app/services/files/base_service.rb b/app/services/files/base_service.rb
index 9a67b160940bfe0ca30b28107c9a1314d002da3a..0326a8823e975c20a7a02825ba1b1da94f27868f 100644
--- a/app/services/files/base_service.rb
+++ b/app/services/files/base_service.rb
@@ -3,8 +3,10 @@ module Files
     class ValidationError < StandardError; end
 
     def execute
-      @current_branch = params[:current_branch]
+      @source_project = params[:source_project] || @project
+      @source_branch = params[:source_branch]
       @target_branch  = params[:target_branch]
+
       @commit_message = params[:commit_message]
       @file_path      = params[:file_path]
       @file_content   = if params[:file_content_encoding] == 'base64'
@@ -16,8 +18,8 @@ module Files
       # Validate parameters
       validate
 
-      # Create new branch if it different from current_branch
-      if @target_branch != @current_branch
+      # Create new branch if it different from source_branch
+      if different_branch?
         create_target_branch
       end
 
@@ -26,18 +28,14 @@ module Files
       else
         error("Something went wrong. Your changes were not committed")
       end
-    rescue Repository::CommitError, GitHooksService::PreReceiveError, ValidationError => ex
+    rescue Repository::CommitError, Gitlab::Git::Repository::InvalidBlobName, GitHooksService::PreReceiveError, ValidationError => ex
       error(ex.message)
     end
 
     private
 
-    def current_branch
-      @current_branch ||= params[:current_branch]
-    end
-
-    def target_branch
-      @target_branch ||= params[:target_branch]
+    def different_branch?
+      @source_branch != @target_branch || @source_project != @project
     end
 
     def raise_error(message)
@@ -52,11 +50,11 @@ module Files
       end
 
       unless project.empty_repo?
-        unless repository.branch_names.include?(@current_branch)
+        unless @source_project.repository.branch_names.include?(@source_branch)
           raise_error("You can only create or edit files when you are on a branch")
         end
 
-        if @current_branch != @target_branch
+        if different_branch?
           if repository.branch_names.include?(@target_branch)
             raise_error("Branch with such name already exists. You need to switch to this branch in order to make changes")
           end
@@ -65,10 +63,10 @@ module Files
     end
 
     def create_target_branch
-      result = CreateBranchService.new(project, current_user).execute(@target_branch, @current_branch)
+      result = CreateBranchService.new(project, current_user).execute(@target_branch, @source_branch, source_project: @source_project)
 
       unless result[:status] == :success
-        raise_error("Something went wrong when we tried to create #{@target_branch} for you")
+        raise_error("Something went wrong when we tried to create #{@target_branch} for you: #{result[:message]}")
       end
     end
   end
diff --git a/app/services/files/create_service.rb b/app/services/files/create_service.rb
index 2348920cc58c25a1900f3a40dd46e3f56dcee36f..e4cde4a2fd84e1ec3143f937a129ab4fbb13662f 100644
--- a/app/services/files/create_service.rb
+++ b/app/services/files/create_service.rb
@@ -26,7 +26,7 @@ module Files
       unless project.empty_repo?
         @file_path.slice!(0) if @file_path.start_with?('/')
 
-        blob = repository.blob_at_branch(@current_branch, @file_path)
+        blob = repository.blob_at_branch(@source_branch, @file_path)
 
         if blob
           raise_error("Your changes could not be committed because a file with the same name already exists")
diff --git a/app/services/issues/close_service.rb b/app/services/issues/close_service.rb
index 3d85f97b7e5a357e4c8188053e5b521f5fe156a1..a1a20e476819df6d507312edd8667da35a4a0016 100644
--- a/app/services/issues/close_service.rb
+++ b/app/services/issues/close_service.rb
@@ -1,6 +1,11 @@
 module Issues
   class CloseService < Issues::BaseService
     def execute(issue, commit = nil)
+      if project.jira_tracker? && project.jira_service.active
+        project.jira_service.execute(commit, issue)
+        return issue
+      end
+
       if project.default_issues_tracker? && issue.close
         event_service.close_issue(issue, current_user)
         create_note(issue, commit)
diff --git a/app/services/projects/update_service.rb b/app/services/projects/update_service.rb
index 69bdd045ddfeece023c92821cd7d7cdb3cd89853..895e089bea3c74f47cb41dd811efe5730cc09b5b 100644
--- a/app/services/projects/update_service.rb
+++ b/app/services/projects/update_service.rb
@@ -3,12 +3,16 @@ module Projects
     def execute
       # check that user is allowed to set specified visibility_level
       new_visibility = params[:visibility_level]
-      if new_visibility && new_visibility.to_i != project.visibility_level
-        unless can?(current_user, :change_visibility_level, project) &&
-          Gitlab::VisibilityLevel.allowed_for?(current_user, new_visibility)
-          deny_visibility_level(project, new_visibility)
-          return project
+      if new_visibility
+        if new_visibility.to_i != project.visibility_level
+          unless can?(current_user, :change_visibility_level, project) &&
+            Gitlab::VisibilityLevel.allowed_for?(current_user, new_visibility)
+            deny_visibility_level(project, new_visibility)
+            return project
+          end
         end
+
+        return false unless visibility_level_allowed?(new_visibility)
       end
 
       new_branch = params[:default_branch]
@@ -23,5 +27,19 @@ module Projects
         end
       end
     end
+
+    private
+
+    def visibility_level_allowed?(level)
+      return true if project.visibility_level_allowed?(level)
+
+      level_name = Gitlab::VisibilityLevel.level_name(level)
+      project.errors.add(
+        :visibility_level,
+        "#{level_name} could not be set as visibility level of this project - parent project settings are more restrictive"
+      )
+
+      false
+    end
   end
 end
diff --git a/app/services/system_note_service.rb b/app/services/system_note_service.rb
index 6975b2ee55b55f2a2c713799cc37221188b91f3c..98a71cbf1ada720854f7627ce00206d709b5206d 100644
--- a/app/services/system_note_service.rb
+++ b/app/services/system_note_service.rb
@@ -241,9 +241,14 @@ class SystemNoteService
       note_options.merge!(noteable: noteable)
     end
 
-    create_note(note_options)
+    if noteable.is_a?(ExternalIssue)
+      noteable.project.issues_tracker.create_cross_reference_note(noteable, mentioner, author)
+    else
+      create_note(note_options)
+    end
   end
 
+
   def self.cross_reference?(note_text)
     note_text.start_with?(cross_reference_note_prefix)
   end
@@ -259,7 +264,7 @@ class SystemNoteService
   #
   # Returns Boolean
   def self.cross_reference_disallowed?(noteable, mentioner)
-    return true if noteable.is_a?(ExternalIssue)
+    return true if noteable.is_a?(ExternalIssue) && !noteable.project.jira_tracker_active?
     return false unless mentioner.is_a?(MergeRequest)
     return false unless noteable.is_a?(Commit)
 
diff --git a/app/views/admin/dashboard/index.html.haml b/app/views/admin/dashboard/index.html.haml
index 8657d2c71fe83eae1a39a5b521ca922acbbdca4c..531247e9148565a0e3b475a435c5a5bd709858bb 100644
--- a/app/views/admin/dashboard/index.html.haml
+++ b/app/views/admin/dashboard/index.html.haml
@@ -79,6 +79,10 @@
         GitLab API
         %span.pull-right
           = API::API::version
+      %p
+        Git
+        %span.pull-right
+          = Gitlab::Git.version
       %p
         Ruby
         %span.pull-right
diff --git a/app/views/admin/identities/index.html.haml b/app/views/admin/identities/index.html.haml
index 8358a14445b24c20eaa0e7edc661f42fd1187c32..741d111fb7d40c3db8e27f3127784eefc652e345 100644
--- a/app/views/admin/identities/index.html.haml
+++ b/app/views/admin/identities/index.html.haml
@@ -1,6 +1,7 @@
 - page_title "Identities", @user.name, "Users"
 = render 'admin/users/head'
 
+= link_to 'New Identity', new_admin_user_identity_path, class: 'pull-right btn btn-new'
 - if @identities.present?
   .table-holder
     %table.table
diff --git a/app/views/admin/identities/new.html.haml b/app/views/admin/identities/new.html.haml
new file mode 100644
index 0000000000000000000000000000000000000000..e30bf0ef0ee23fd90f03946282c2ecf315e4b316
--- /dev/null
+++ b/app/views/admin/identities/new.html.haml
@@ -0,0 +1,4 @@
+- page_title "New Identity"
+%h3.page-title New identity
+%hr
+= render 'form'
diff --git a/app/views/admin/runners/index.html.haml b/app/views/admin/runners/index.html.haml
index c5fb3c95506e2ea52b4bcc2ae8b17d78525747d3..c407972cd0875dd3c4b329acd7c649216eccf0f5 100644
--- a/app/views/admin/runners/index.html.haml
+++ b/app/views/admin/runners/index.html.haml
@@ -3,7 +3,7 @@
     To register a new runner you should enter the following registration token.
     With this token the runner will request a unique runner token and use that for future communication.
     Registration token is
-    %code{ id: 'runners-token' } #{current_application_settings.ensure_runners_registration_token}
+    %code{ id: 'runners-token' } #{current_application_settings.runners_registration_token}
 
 .bs-callout.clearfix
   .pull-left
diff --git a/app/views/ci/lints/_create.html.haml b/app/views/ci/lints/_create.html.haml
index 77f78caa8d886ac22324b676429399862314e8e3..f7875e68b7e668745e10e238e7c7d1899b820a66 100644
--- a/app/views/ci/lints/_create.html.haml
+++ b/app/views/ci/lints/_create.html.haml
@@ -41,5 +41,3 @@
     %i.fa.fa-remove.incorrect-syntax
   %b Error:
   = @error
-
-    
diff --git a/app/views/ci/lints/create.js.haml b/app/views/ci/lints/create.js.haml
deleted file mode 100644
index a96c0b11b6e06cb89baed0c3730f8c028883f675..0000000000000000000000000000000000000000
--- a/app/views/ci/lints/create.js.haml
+++ /dev/null
@@ -1,2 +0,0 @@
-:plain
-  $(".results").html("#{escape_javascript(render "create")}")
\ No newline at end of file
diff --git a/app/views/ci/lints/show.html.haml b/app/views/ci/lints/show.html.haml
index fb9057e4882069229f557c83af711e1dbc719ab3..a144c43be477a260ccdad87422f114634285f135 100644
--- a/app/views/ci/lints/show.html.haml
+++ b/app/views/ci/lints/show.html.haml
@@ -1,27 +1,17 @@
 %h2 Check your .gitlab-ci.yml
 %hr
 
-= form_tag ci_lint_path, method: :post, remote: true do
-  .control-group
-    = label_tag :content, "Content of .gitlab-ci.yml", class: 'control-label'
-    .controls
-      = text_area_tag :content, nil, class: 'form-control span1', rows: 7, require: true
+.row
+  = form_tag ci_lint_path, method: :post do
+    .form-group
+      = label_tag :content, 'Content of .gitlab-ci.yml', class: 'control-label text-nowrap'
+      .col-sm-12
+        = text_area_tag :content, nil, class: 'form-control span1', rows: 7, require: true
+    .col-sm-12
+      .pull-left.prepend-top-10
+        = submit_tag 'Validate', class: 'btn btn-success submit-yml'
 
-  .control-group.clearfix
-    .controls.pull-left.prepend-top-10
-      = submit_tag "Validate", class: 'btn btn-success submit-yml'
-
-
-%p.text-center.loading
-  %i.fa.fa-refresh.fa-spin
-
-.results.prepend-top-20
-
-:javascript
-  $(".loading").hide();
-  $('form').bind('ajax:beforeSend', function() {
-    $(".loading").show();
-  });
-  $('form').bind('ajax:complete', function() {
-    $(".loading").hide();
-  });
+.row.prepend-top-20
+  .col-sm-12
+    .results
+      = render partial: 'create' if defined?(@status)
diff --git a/app/views/dashboard/_projects_head.html.haml b/app/views/dashboard/_projects_head.html.haml
index 2e77afb7525923d48e085aaaf47d61cc39c1e781..f4a3e3162bf5da1eeaecc7d4b6b56f290a94f427 100644
--- a/app/views/dashboard/_projects_head.html.haml
+++ b/app/views/dashboard/_projects_head.html.haml
@@ -1,13 +1,20 @@
 = content_for :flash_message do
   = render 'shared/project_limit'
+.top-area
+  %ul.left-top-menu
+    = nav_link(page: [dashboard_projects_path, root_path]) do
+      = link_to dashboard_projects_path, title: 'Home', class: 'shortcuts-activity', data: {placement: 'right'} do
+        Your Projects
+    = nav_link(page: starred_dashboard_projects_path) do
+      = link_to starred_dashboard_projects_path, title: 'Starred Projects', data: {placement: 'right'} do
+        Starred Projects
+    = nav_link(page: [explore_root_path, trending_explore_projects_path, starred_explore_projects_path, explore_projects_path], html_options: { class: 'hidden-xs' }) do
+      = link_to explore_root_path, title: 'Explore', data: {placement: 'right'} do
+        Explore Projects
 
-%ul.center-top-menu
-  = nav_link(page: [dashboard_projects_path, root_path]) do
-    = link_to dashboard_projects_path, title: 'Home', class: 'shortcuts-activity', data: {placement: 'right'} do
-      Your Projects
-  = nav_link(page: starred_dashboard_projects_path) do
-    = link_to starred_dashboard_projects_path, title: 'Starred Projects', data: {placement: 'right'} do
-      Starred Projects
-  = nav_link(page: [explore_root_path, trending_explore_projects_path, starred_explore_projects_path, explore_projects_path], html_options: { class: 'hidden-xs' }) do
-    = link_to explore_root_path, title: 'Explore', data: {placement: 'right'} do
-      Explore Projects
+  .projects-search-form  
+    = search_field_tag :filter_projects, nil, placeholder: 'Filter by name...', class: 'projects-list-filter form-control hidden-xs', spellcheck: false
+    - if current_user.can_create_project?
+      = link_to new_project_path, class: 'btn btn-green' do
+        %i.fa.fa-plus
+        New Project
diff --git a/app/views/dashboard/projects/_projects.html.haml b/app/views/dashboard/projects/_projects.html.haml
index 81a5909e2d2ac5f01430f000bf0512306320cedd..cea9ffcc748ad866e87d924b1785da19b94f10e4 100644
--- a/app/views/dashboard/projects/_projects.html.haml
+++ b/app/views/dashboard/projects/_projects.html.haml
@@ -1,11 +1,3 @@
 .projects-list-holder
-  .projects-search-form
-    .input-group
-      = search_field_tag :filter_projects, nil, placeholder: 'Filter by name', class: 'projects-list-filter form-control', spellcheck: false
-      - if current_user.can_create_project?
-        %span.input-group-btn
-          = link_to new_project_path, class: 'btn btn-green' do
-            %i.fa.fa-plus
-            New Project
 
   = render 'shared/projects/list', projects: @projects, ci: true
diff --git a/app/views/devise/mailer/unlock_instructions.html.erb b/app/views/devise/mailer/unlock_instructions.html.erb
deleted file mode 100644
index 79d6c761d8fce48f4bf9e757392c13cff3ecf16d..0000000000000000000000000000000000000000
--- a/app/views/devise/mailer/unlock_instructions.html.erb
+++ /dev/null
@@ -1,7 +0,0 @@
-<p>Hello <%= @resource.email %>!</p>
-
-<p>Your account has been locked due to an excessive amount of unsuccessful sign in attempts.</p>
-
-<p>Click the link below to unlock your account:</p>
-
-<p><%= link_to 'Unlock your account', unlock_url(@resource, unlock_token: @token) %></p>
diff --git a/app/views/devise/mailer/unlock_instructions.html.haml b/app/views/devise/mailer/unlock_instructions.html.haml
new file mode 100644
index 0000000000000000000000000000000000000000..52b327e20c5f71dec4a876fa2585ebfc921066c1
--- /dev/null
+++ b/app/views/devise/mailer/unlock_instructions.html.haml
@@ -0,0 +1,10 @@
+%p
+Hello #{@resource.name}!
+
+%p
+  Your GitLab account has been locked due to an excessive amount of unsuccessful
+  sign in attempts. Your account will automatically unlock in
+  = time_ago_in_words(Devise.unlock_in.from_now)
+  or you may click the link below to unlock now.
+
+%p= link_to 'Unlock your account', unlock_url(@resource, unlock_token: @token)
diff --git a/app/views/devise/unlocks/new.html.erb b/app/views/devise/unlocks/new.html.erb
deleted file mode 100644
index f9277d1673fe35c0ab7a80339cb20c1159871823..0000000000000000000000000000000000000000
--- a/app/views/devise/unlocks/new.html.erb
+++ /dev/null
@@ -1,12 +0,0 @@
-<h2>Resend unlock instructions</h2>
-
-<%= form_for(resource, as: resource_name, url: unlock_path(resource_name), html: { method: :post }) do |f| %>
-  <%= devise_error_messages! %>
-
-  <div><%= f.label :email %><br />
-  <%= f.email_field :email %></div>
-
-  <div><%= f.submit "Resend unlock instructions" %></div>
-<% end %>
-
-<%= render partial: "devise/shared/links" %>
diff --git a/app/views/devise/unlocks/new.html.haml b/app/views/devise/unlocks/new.html.haml
new file mode 100644
index 0000000000000000000000000000000000000000..49c087c0646e42112a6266225eb0ecf0aa225039
--- /dev/null
+++ b/app/views/devise/unlocks/new.html.haml
@@ -0,0 +1,14 @@
+.login-box
+  .login-heading
+    %h3 Resend unlock email
+  .login-body
+    = form_for(resource, as: resource_name, url: unlock_path(resource_name), html: { method: :post }) do |f|
+      .devise-errors
+        = devise_error_messages!
+      .clearfix.append-bottom-20
+        = f.email_field :email, class: 'form-control', placeholder: 'Email', autofocus: 'autofocus', autocapitalize: 'off', autocorrect: 'off'
+      .clearfix
+        = f.submit 'Resend unlock instructions', class: 'btn btn-success'
+
+.clearfix.prepend-top-20
+  = render 'devise/shared/sign_in_link'
diff --git a/app/views/explore/projects/index.html.haml b/app/views/explore/projects/index.html.haml
index 76bdd68fd764b3f8a7f9f8d0f7683adb0fc06e35..b9a958fbe7be505ab4a7aa705e91beef3dc518d4 100644
--- a/app/views/explore/projects/index.html.haml
+++ b/app/views/explore/projects/index.html.haml
@@ -6,7 +6,7 @@
 - else
   = render 'explore/head'
 
-.gray-content-block.clearfix
+.gray-content-block.clearfix.second-block
   = render 'filter'
 = render 'projects', projects: @projects
 = paginate @projects, theme: "gitlab"
diff --git a/app/views/explore/projects/starred.html.haml b/app/views/explore/projects/starred.html.haml
index e30c3633223c026e86400fa0c47a7283e63d0aa9..95d46e331f8a1d4dc41aeee78142645c349440cc 100644
--- a/app/views/explore/projects/starred.html.haml
+++ b/app/views/explore/projects/starred.html.haml
@@ -7,7 +7,7 @@
   = render 'explore/head'
 
 .explore-trending-block
-  .gray-content-block
+  .gray-content-block.second-block
     .pull-right
       = render 'explore/projects/dropdown'
     .oneline
diff --git a/app/views/explore/projects/trending.html.haml b/app/views/explore/projects/trending.html.haml
index 1412b19acde9b2fa25ea5f5596a8e965d4d106ec..fa0b718e48b7b37c6fc02b2dd347b9875a5d8264 100644
--- a/app/views/explore/projects/trending.html.haml
+++ b/app/views/explore/projects/trending.html.haml
@@ -7,7 +7,7 @@
   = render 'explore/head'
 
 .explore-trending-block
-  .gray-content-block
+  .gray-content-block.second-block
     .pull-right
       = render 'explore/projects/dropdown'
     .oneline
diff --git a/app/views/groups/_projects.html.haml b/app/views/groups/_projects.html.haml
index 11d69977ef9e03b87fd2c5bb113cd131651fb1d7..bbafc08435af438ca1f99bd3948208d73138910f 100644
--- a/app/views/groups/_projects.html.haml
+++ b/app/views/groups/_projects.html.haml
@@ -1,5 +1,5 @@
-.panel.panel-default.projects-list-holder
-  .panel-heading.clearfix
+.projects-list-holder
+  .projects-search-form
     .input-group
       = search_field_tag :filter_projects, nil, placeholder: 'Filter by name', class: 'projects-list-filter form-control', spellcheck: false
       - if can? current_user, :create_projects, @group
diff --git a/app/views/groups/show.html.haml b/app/views/groups/show.html.haml
index dc8e81323a63daf43f7e527162142042b3a37111..c2c7c581b3eff57c5ad3d522f86bc77544a72709 100644
--- a/app/views/groups/show.html.haml
+++ b/app/views/groups/show.html.haml
@@ -5,37 +5,47 @@
   - if current_user
     = auto_discovery_link_tag(:atom, group_url(@group, format: :atom, private_token: current_user.private_token), title: "#{@group.name} activity")
 
-.dashboard
-  .header-with-avatar.clearfix
-    = image_tag group_icon(@group), class: "avatar group-avatar s90"
-    %h3
-      = @group.name
-    .username
-      @#{@group.path}
-    - if @group.description.present?
-      .description
-        = markdown(@group.description, pipeline: :description)
-  %hr
-
-  = render 'shared/show_aside'
-
-  - if can?(current_user, :read_group, @group)
-    .row
-      %section.activities.col-md-7
-        .hidden-xs
-          - if current_user
-            = render "events/event_last_push", event: @last_push
-            .pull-right
-              = link_to group_path(@group, { format: :atom, private_token: current_user.private_token }), title: "Feed", class: 'btn rss-btn' do
-                %i.fa.fa-rss
-
-            = render 'shared/event_filter'
-            %hr
-
-        .content_list
-        = spinner
-      %aside.side.col-md-5
-        = render "projects", projects: @projects
-  - else
-    %p
-      This group does not have public projects
+.cover-block
+  .avatar-holder
+    = link_to group_icon(@group), target: '_blank' do
+      = image_tag group_icon(@group), class: "avatar group-avatar s90"
+  .cover-title
+    = @group.name
+
+  .cover-desc.username
+    @#{@group.path}
+
+  - if @group.description.present?
+    .cover-desc.description
+      = markdown(@group.description, pipeline: :description)
+
+- if can?(current_user, :read_group, @group)
+  %ul.center-top-menu.no-top
+    %li.active
+      = link_to "#activity", 'data-toggle' => 'tab' do
+        Activity
+    - if @projects.present?
+      %li
+        = link_to "#projects", 'data-toggle' => 'tab' do
+          Projects
+
+  .tab-content
+    .tab-pane.active#activity
+      .gray-content-block.activity-filter-block
+        - if current_user
+          = render "events/event_last_push", event: @last_push
+          .pull-right
+            = link_to group_path(@group, { format: :atom, private_token: current_user.private_token }), title: "Feed", class: 'btn rss-btn' do
+              %i.fa.fa-rss
+
+          = render 'shared/event_filter'
+
+      .content_list
+      = spinner
+
+    .tab-pane#projects
+      = render "projects", projects: @projects
+
+- else
+  %p
+    This group does not have public projects
diff --git a/app/views/profiles/keys/new.html.haml b/app/views/profiles/keys/new.html.haml
index 11166dc6d9985e4b626289a4e28b09c817533c78..13a18269d11b57c0dc2fd6ee3ca257ce59cd4306 100644
--- a/app/views/profiles/keys/new.html.haml
+++ b/app/views/profiles/keys/new.html.haml
@@ -12,6 +12,6 @@
         comment = val.match(/^\S+ \S+ (.+)\n?$/);
 
     if( comment && comment.length > 1 && title.val() == '' ){
-      $('#key_title').val( comment[1] );
+      $('#key_title').val( comment[1] ).change();
     }
   });
diff --git a/app/views/projects/_commit_button.html.haml b/app/views/projects/_commit_button.html.haml
index 2fd3d9e1be454bc889bc57c9419f5c9b9583b502..640612ca433d0ac29e6bb6381d914c001a6925cf 100644
--- a/app/views/projects/_commit_button.html.haml
+++ b/app/views/projects/_commit_button.html.haml
@@ -2,3 +2,7 @@
   = button_tag 'Commit Changes', class: 'btn commit-btn js-commit-button btn-create'
   = link_to 'Cancel', cancel_path,
             class: 'btn btn-cancel', data: {confirm: leave_edit_message}
+
+  - unless can?(current_user, :push_code, @project)
+    .inline.prepend-left-10
+      = commit_in_fork_help
diff --git a/app/views/projects/_home_panel.html.haml b/app/views/projects/_home_panel.html.haml
index c1669ac046b4207ae92914d078b0871e8e8bec0b..e92115b9b987ba29111ba28c8f6be4991c7816c6 100644
--- a/app/views/projects/_home_panel.html.haml
+++ b/app/views/projects/_home_panel.html.haml
@@ -27,7 +27,7 @@
         = icon('rss')
 
   .project-repo-buttons
-    .split-one
+    .split-one.count-buttons
       = render 'projects/buttons/star'
       = render 'projects/buttons/fork'
 
@@ -38,3 +38,6 @@
       = render 'projects/buttons/dropdown'
 
     = render 'projects/buttons/notifications'
+
+:coffeescript
+  new Star()
\ No newline at end of file
diff --git a/app/views/projects/blob/_actions.html.haml b/app/views/projects/blob/_actions.html.haml
index b1df8d19938326eab5ec0622846a3d401257a5d3..cdac50f7a8d3a5c7c14d57659c38b114ae8262e9 100644
--- a/app/views/projects/blob/_actions.html.haml
+++ b/app/views/projects/blob/_actions.html.haml
@@ -2,7 +2,7 @@
   = link_to 'Raw', namespace_project_raw_path(@project.namespace, @project, @id),
       class: 'btn btn-sm', target: '_blank'
   -# only show normal/blame view links for text files
-  - if blob_viewable?(@blob)
+  - if blob_text_viewable?(@blob)
     - if current_page? namespace_project_blame_path(@project.namespace, @project, @id)
       = link_to 'Normal View', namespace_project_blob_path(@project.namespace, @project, @id),
           class: 'btn btn-sm'
@@ -14,13 +14,8 @@
   = link_to 'Permalink', namespace_project_blob_path(@project.namespace, @project,
       tree_join(@commit.sha, @path)), class: 'btn btn-sm'
 
-- if blob_editable?(@blob)
+- if current_user
   .btn-group{ role: "group" }
-    = edit_blob_link(@project, @ref, @path)
-    %button.btn.btn-default{ 'data-target' => '#modal-upload-blob', 'data-toggle' => 'modal' } Replace
-    %button.btn.btn-remove{ 'data-target' => '#modal-remove-blob', 'data-toggle' => 'modal' } Delete
-- elsif !on_top_of_branch?
-  .btn-group{ role: "group" }
-    %button.btn.btn-default.disabled.has_tooltip{title: "You can only edit files when you are on a branch.", data: {container: 'body'}} Edit
-    %button.btn.btn-default.disabled.has_tooltip{title: "You can only replace files when you are on a branch.", data: {container: 'body'}} Replace
-    %button.btn.btn-remove.disabled.has_tooltip{title: "You can only delete files when you are on a branch.", data: {container: 'body'}} Delete
+    = edit_blob_link
+    = replace_blob_link
+    = delete_blob_link
diff --git a/app/views/projects/blob/_new_dir.html.haml b/app/views/projects/blob/_new_dir.html.haml
index fc6c9f5fd094d8f57c5252324e734852554f943c..084608bbba38c7a5f64fb923ec7ce9e868b88a86 100644
--- a/app/views/projects/blob/_new_dir.html.haml
+++ b/app/views/projects/blob/_new_dir.html.haml
@@ -17,5 +17,9 @@
             = submit_tag "Create directory", class: 'btn btn-create'
             = link_to "Cancel", '#', class: "btn btn-cancel", "data-dismiss" => "modal"
 
+            - unless can?(current_user, :push_code, @project)
+              .inline.prepend-left-10
+                = commit_in_fork_help
+
 :javascript
   new NewCommitForm($('.js-create-dir-form'))
diff --git a/app/views/projects/blob/_upload.html.haml b/app/views/projects/blob/_upload.html.haml
index ecc90a30e78869103b0930f68e3d2d6cef7ba62d..676924dc6ca2d366ba98717f882c20a4b837682d 100644
--- a/app/views/projects/blob/_upload.html.haml
+++ b/app/views/projects/blob/_upload.html.haml
@@ -20,6 +20,11 @@
             = button_tag button_title, class: 'btn btn-small btn-create btn-upload-file', id: 'submit-all'
             = link_to "Cancel", '#', class: "btn btn-cancel", "data-dismiss" => "modal"
 
+            - unless can?(current_user, :push_code, @project)
+              .inline.prepend-left-10
+                = commit_in_fork_help
+
+
 :javascript
   disableButtonIfEmptyField($('.js-upload-blob-form').find('.js-commit-message'), '.btn-upload-file');
   new BlobFileDropzone($('.js-upload-blob-form'), '#{method}');
diff --git a/app/views/projects/blob/edit.html.haml b/app/views/projects/blob/edit.html.haml
index a47fe7ede8059d19e7839114d90d855970b3bdb3..09fa148b129b03ec047f78748462478afe4784df 100644
--- a/app/views/projects/blob/edit.html.haml
+++ b/app/views/projects/blob/edit.html.haml
@@ -20,7 +20,7 @@
     = hidden_field_tag 'last_commit', @last_commit
     = hidden_field_tag 'content', '', id: "file-content"
     = hidden_field_tag 'from_merge_request_id', params[:from_merge_request_id]
-    = render 'projects/commit_button', ref: @ref, cancel_path: @after_edit_path
+    = render 'projects/commit_button', ref: @ref, cancel_path: namespace_project_blob_path(@project.namespace, @project, @id)
 
 :javascript
   blob = new EditBlob(gon.relative_url_root + "#{Gitlab::Application.config.assets.prefix}", "#{@blob.language.try(:ace_mode)}")
diff --git a/app/views/projects/blob/show.html.haml b/app/views/projects/blob/show.html.haml
index 3f8d11ed8c85614ceec49bd1df31d3a63c77942c..6988039b6c7233e30de71f7fc300fa7a949b18d0 100644
--- a/app/views/projects/blob/show.html.haml
+++ b/app/views/projects/blob/show.html.haml
@@ -6,7 +6,7 @@
 %div#tree-holder.tree-holder
   = render 'blob', blob: @blob
 
-- if blob_editable?(@blob)
+- if can_edit_blob?(@blob)
   = render 'projects/blob/remove'
 
   - title = "Replace #{@blob.name}"
diff --git a/app/views/projects/branches/new.html.haml b/app/views/projects/branches/new.html.haml
index 31943a2407a275fd00717251fdfb2f287678298d..c659af6338c477dacc83c28417567c7064f20c0b 100644
--- a/app/views/projects/branches/new.html.haml
+++ b/app/views/projects/branches/new.html.haml
@@ -9,11 +9,12 @@
   New Branch
 %hr
 
-= form_tag namespace_project_branches_path, method: :post, id: "new-branch-form", class: "form-horizontal js-requires-input" do
+= form_tag namespace_project_branches_path, method: :post, id: "new-branch-form", class: "form-horizontal js-create-branch-form js-requires-input" do
   .form-group
     = label_tag :branch_name, nil, class: 'control-label'
     .col-sm-10
-      = text_field_tag :branch_name, params[:branch_name], required: true, tabindex: 1, autofocus: true, class: 'form-control'
+      = text_field_tag :branch_name, params[:branch_name], required: true, tabindex: 1, autofocus: true, class: 'form-control js-branch-name'
+      .help-block.text-danger.js-branch-name-error
   .form-group
     = label_tag :ref, 'Create from', class: 'control-label'
     .col-sm-10
@@ -26,7 +27,4 @@
 :javascript
   var availableRefs = #{@project.repository.ref_names.to_json};
 
-  $("#ref").autocomplete({
-    source: availableRefs,
-    minLength: 1
-  });
+  new NewBranchForm($('.js-create-branch-form'), availableRefs)
diff --git a/app/views/projects/builds/show.html.haml b/app/views/projects/builds/show.html.haml
index 20a5b6a66e7038d573028777ec9c4c3a457ad9fb..5b7ecce86ab2b9041019e526650a50e45eb124a0 100644
--- a/app/views/projects/builds/show.html.haml
+++ b/app/views/projects/builds/show.html.haml
@@ -7,6 +7,10 @@
     %strong.monospace= link_to @build.commit.short_sha, ci_status_path(@build.commit)
     from
     = link_to @build.ref, namespace_project_commits_path(@project.namespace, @project, @build.ref)
+    - merge_request = @build.merge_request
+    - if merge_request
+      via
+      = link_to "merge request ##{merge_request.iid}", merge_request_path(merge_request)
 
   #up-build-trace
   - if @commit.matrix_for_ref?(@build.ref)
diff --git a/app/views/projects/buttons/_dropdown.html.haml b/app/views/projects/buttons/_dropdown.html.haml
index b277b765b6b526a0c123e01823c0e9cdd9012f5a..1f639fecc308decd4fb7bff135ec9c6be8ca2108 100644
--- a/app/views/projects/buttons/_dropdown.html.haml
+++ b/app/views/projects/buttons/_dropdown.html.haml
@@ -18,10 +18,11 @@
           = link_to new_namespace_project_snippet_path(@project.namespace, @project) do
             = icon('file-text-o fw')
             New snippet
+
       - if can?(current_user, :push_code, @project)
         %li.divider
         %li
-          = link_to namespace_project_new_blob_path(@project.namespace, @project, @project.default_branch || 'master'), title: 'New file' do
+          = link_to namespace_project_new_blob_path(@project.namespace, @project, @project.default_branch || 'master') do
             = icon('file fw')
             New file
         %li
@@ -32,3 +33,20 @@
           = link_to new_namespace_project_tag_path(@project.namespace, @project) do
             = icon('tags fw')
             New tag
+      - elsif current_user && current_user.already_forked?(@project)
+        %li.divider
+        %li
+          = link_to namespace_project_new_blob_path(@project.namespace, @project, @project.default_branch || 'master') do
+            = icon('file fw')
+            New file
+      - elsif can?(current_user, :fork_project, @project)
+        %li.divider
+        %li
+          - continue_params = { to:         namespace_project_new_blob_path(@project.namespace, @project, @project.default_branch || 'master'),
+                                notice:     edit_in_new_fork_notice,
+                                notice_now: edit_in_new_fork_notice_now }
+          - fork_path = namespace_project_fork_path(@project.namespace, @project, namespace_key:  current_user.namespace.id,
+                                                                                  continue:       continue_params)
+          = link_to fork_path, method: :post do
+            = icon('file fw')
+            New file
diff --git a/app/views/projects/buttons/_fork.html.haml b/app/views/projects/buttons/_fork.html.haml
index 2d3abf09051852a7bab10bf71923ce8726e86614..133531887a202cfabb18762643723d48d437c55f 100644
--- a/app/views/projects/buttons/_fork.html.haml
+++ b/app/views/projects/buttons/_fork.html.haml
@@ -4,10 +4,15 @@
       = link_to namespace_project_path(current_user, current_user.fork_of(@project)), title: 'Go to your fork', class: 'btn has_tooltip' do
         = icon('code-fork fw')
         Fork
+      %div.count-with-arrow
+        %span.arrow
         %span.count
           = @project.forks_count
     - else
       = link_to new_namespace_project_fork_path(@project.namespace, @project), title: "Fork project", class: 'btn has_tooltip' do
         = icon('code-fork fw')
+        Fork
+      %div.count-with-arrow
+        %span.arrow
         %span.count
           = @project.forks_count
diff --git a/app/views/projects/buttons/_star.html.haml b/app/views/projects/buttons/_star.html.haml
index 41a3ec6d90fafbed9a389e5cd59486ad678c4837..21ba426aaa1e779a139aa29bc25ecc32be41c49f 100644
--- a/app/views/projects/buttons/_star.html.haml
+++ b/app/views/projects/buttons/_star.html.haml
@@ -1,19 +1,21 @@
 - if current_user
   = link_to toggle_star_namespace_project_path(@project.namespace, @project), class: 'btn star-btn toggle-star has_tooltip', method: :post, remote: true, title: "Star project" do
-    = icon('star fw')
-    %span.count
+    - if current_user.starred?(@project)
+      = icon('star fw')
+      %span.starred Unstar
+    - else
+      = icon('star-o fw')
+      %span Star
+  %div.count-with-arrow
+    %span.arrow
+    %span.count.star-count
       = @project.star_count
 
-  :javascript
-    $('.project-home-panel .toggle-star').on('ajax:success', function (e, data, status, xhr) {
-      $(this).replaceWith(data.html);
-    })
-    .on('ajax:error', function (e, xhr, status, error) {
-      new Flash('Star toggle failed. Try again later.', 'alert');
-    });
-
 - else
   = link_to new_user_session_path, class: 'btn has_tooltip star-btn', title: 'You must sign in to star a project' do
     = icon('star fw')
+    Star
+  %div.count-with-arrow
+    %span.arrow
     %span.count
       = @project.star_count
diff --git a/app/views/projects/diffs/_file.html.haml b/app/views/projects/diffs/_file.html.haml
index 327e7d9245a625f916a538e0d3805a546c99d3db..517f6aef7c5a89e356407058e781455467cb8640 100644
--- a/app/views/projects/diffs/_file.html.haml
+++ b/app/views/projects/diffs/_file.html.haml
@@ -24,7 +24,7 @@
             = "#{diff_file.diff.a_mode} → #{diff_file.diff.b_mode}"
 
       .diff-controls
-        - if blob_viewable?(blob)
+        - if blob_text_viewable?(blob)
           = link_to '#', class: 'js-toggle-diff-comments btn btn-sm active has_tooltip', title: "Toggle comments for this file" do
             %i.fa.fa-comments
           &nbsp;
@@ -32,14 +32,15 @@
         - if editable_diff?(diff_file)
           = edit_blob_link(@merge_request.source_project,
               @merge_request.source_branch, diff_file.new_path,
-              after: '&nbsp;', from_merge_request_id: @merge_request.id)
+              from_merge_request_id: @merge_request.id)
+          &nbsp;
 
         = view_file_btn(diff_commit.id, diff_file, project)
 
   .diff-content.diff-wrap-lines
     -# Skipp all non non-supported blobs
     - return unless blob.respond_to?('text?')
-    - if blob_viewable?(blob)
+    - if blob_text_viewable?(blob)
       - if diff_view == 'parallel'
         = render "projects/diffs/parallel_view", diff_file: diff_file, project: project, blob: blob, index: i
       - else
diff --git a/app/views/projects/forks/new.html.haml b/app/views/projects/forks/new.html.haml
index f0b0a11c04a30de76383dd410d22bac157c3d580..8a2c027a45517d6ad288122d5b416c840f9ac006 100644
--- a/app/views/projects/forks/new.html.haml
+++ b/app/views/projects/forks/new.html.haml
@@ -43,4 +43,3 @@
       %i.fa.fa-spinner.fa-spin
       Forking repository
     %p Please wait a moment, this page will automatically refresh when ready.
-
diff --git a/app/views/projects/issues/_discussion.html.haml b/app/views/projects/issues/_discussion.html.haml
index 86d3dc546ba879b825c9873d82600b7fbd42a961..dc434cf38c4ab006432903456cfd5dace77a4865 100644
--- a/app/views/projects/issues/_discussion.html.haml
+++ b/app/views/projects/issues/_discussion.html.haml
@@ -1,9 +1,9 @@
 - content_for :note_actions do
   - if can?(current_user, :update_issue, @issue)
     - if @issue.closed?
-      = link_to 'Reopen Issue', issue_path(@issue, issue: {state_event: :reopen}, status_only: true), method: :put, class: 'btn btn-grouped btn-reopen js-note-target-reopen', title: 'Reopen Issue'
+      = link_to 'Reopen Issue', issue_path(@issue, issue: {state_event: :reopen}, status_only: true), method: :put, class: 'btn btn-nr btn-grouped btn-reopen js-note-target-reopen', title: 'Reopen Issue'
     - else
-      = link_to 'Close Issue', issue_path(@issue, issue: {state_event: :close}, status_only: true), method: :put, class: 'btn btn-grouped btn-close js-note-target-close', title: 'Close Issue'
+      = link_to 'Close Issue', issue_path(@issue, issue: {state_event: :close}, status_only: true), method: :put, class: 'btn btn-nr btn-grouped btn-close js-note-target-close', title: 'Close Issue'
 
 #notes
   = render 'projects/notes/notes_with_form'
diff --git a/app/views/projects/issues/show.html.haml b/app/views/projects/issues/show.html.haml
index 2fe6f88b2a9be419058e838a1ab0cadee534dac8..b6efa05a1ae38b10727bd518e3ad164f2e4f4fab 100644
--- a/app/views/projects/issues/show.html.haml
+++ b/app/views/projects/issues/show.html.haml
@@ -23,16 +23,16 @@
 
     .pull-right
       - if can?(current_user, :create_issue, @project)
-        = link_to new_namespace_project_issue_path(@project.namespace, @project), class: 'btn btn-grouped new-issue-link', title: 'New Issue', id: 'new_issue_link' do
+        = link_to new_namespace_project_issue_path(@project.namespace, @project), class: 'btn btn-nr btn-grouped new-issue-link btn-success', title: 'New Issue', id: 'new_issue_link' do
           = icon('plus')
           New Issue
       - if can?(current_user, :update_issue, @issue)
         - if @issue.closed?
-          = link_to 'Reopen', issue_path(@issue, issue: {state_event: :reopen}, status_only: true), method: :put, class: 'btn btn-grouped btn-reopen'
+          = link_to 'Reopen', issue_path(@issue, issue: {state_event: :reopen}, status_only: true), method: :put, class: 'btn btn-nr btn-grouped btn-reopen'
         - else
-          = link_to 'Close', issue_path(@issue, issue: {state_event: :close}, status_only: true), method: :put, class: 'btn btn-grouped btn-close', title: 'Close Issue'
+          = link_to 'Close', issue_path(@issue, issue: {state_event: :close}, status_only: true), method: :put, class: 'btn btn-nr btn-grouped btn-close', title: 'Close Issue'
 
-        = link_to edit_namespace_project_issue_path(@project.namespace, @project, @issue), class: 'btn btn-grouped issuable-edit' do
+        = link_to edit_namespace_project_issue_path(@project.namespace, @project, @issue), class: 'btn btn-nr btn-grouped issuable-edit' do
           = icon('pencil-square-o')
           Edit
 
diff --git a/app/views/projects/merge_requests/_discussion.html.haml b/app/views/projects/merge_requests/_discussion.html.haml
index 399e9cc1e1b33bb16d5a1eda771935e48bffedc4..bff3c3b283ddf33a3fee9104980120eb62136021 100644
--- a/app/views/projects/merge_requests/_discussion.html.haml
+++ b/app/views/projects/merge_requests/_discussion.html.haml
@@ -1,8 +1,8 @@
 - content_for :note_actions do
   - if can?(current_user, :update_merge_request, @merge_request)
     - if @merge_request.open?
-      = link_to 'Close', merge_request_path(@merge_request, merge_request: {state_event: :close }), method: :put, class: "btn btn-grouped btn-close close-mr-link js-note-target-close", title: "Close merge request"
+      = link_to 'Close', merge_request_path(@merge_request, merge_request: {state_event: :close }), method: :put, class: "btn btn-nr btn-grouped btn-close close-mr-link js-note-target-close", title: "Close merge request"
     - if @merge_request.closed?
-      = link_to 'Reopen', merge_request_path(@merge_request, merge_request: {state_event: :reopen }), method: :put, class: "btn btn-grouped btn-reopen reopen-mr-link js-note-target-reopen", title: "Reopen merge request"
+      = link_to 'Reopen', merge_request_path(@merge_request, merge_request: {state_event: :reopen }), method: :put, class: "btn btn-nr btn-grouped btn-reopen reopen-mr-link js-note-target-reopen", title: "Reopen merge request"
 
 #notes= render "projects/notes/notes_with_form"
diff --git a/app/views/projects/merge_requests/_merge_request.html.haml b/app/views/projects/merge_requests/_merge_request.html.haml
index 105c731c7e14a2327c9086107d20046ca7446160..a051729dc3202221a75da4595df695a9f4eaead2 100644
--- a/app/views/projects/merge_requests/_merge_request.html.haml
+++ b/app/views/projects/merge_requests/_merge_request.html.haml
@@ -17,7 +17,7 @@
 
       - if merge_request.open? && merge_request.broken?
         %li
-          = link_to merge_request_path(merge_request), class: "has_tooltip", title: "Cannot be merged automatically", data: {container: 'body'} do
+          = link_to merge_request_path(merge_request), class: "has_tooltip", title: "Cannot be merged automatically", data: { container: 'body' } do
             = icon('exclamation-triangle')
 
       - if merge_request.assignee
diff --git a/app/views/projects/merge_requests/show/_mr_title.html.haml b/app/views/projects/merge_requests/show/_mr_title.html.haml
index 473124480ac7c7e75aa03206df02a5536819db10..fc6fb2a0d42f56b243870a06a83d27d722a7d6ee 100644
--- a/app/views/projects/merge_requests/show/_mr_title.html.haml
+++ b/app/views/projects/merge_requests/show/_mr_title.html.haml
@@ -17,9 +17,9 @@
   .issue-btn-group.pull-right
     - if can?(current_user, :update_merge_request, @merge_request)
       - if @merge_request.open?
-        = link_to 'Close', merge_request_path(@merge_request, merge_request: { state_event: :close }), method: :put, class: 'btn btn-grouped btn-close', title: 'Close merge request'
-        = link_to edit_namespace_project_merge_request_path(@project.namespace, @project, @merge_request), class: 'btn btn-grouped issuable-edit', id: 'edit_merge_request' do
+        = link_to 'Close', merge_request_path(@merge_request, merge_request: { state_event: :close }), method: :put, class: 'btn btn-nr btn-grouped btn-close', title: 'Close merge request'
+        = link_to edit_namespace_project_merge_request_path(@project.namespace, @project, @merge_request), class: 'btn btn-nr btn-grouped issuable-edit', id: 'edit_merge_request' do
           %i.fa.fa-pencil-square-o
           Edit
       - if @merge_request.closed?
-        = link_to 'Reopen', merge_request_path(@merge_request, merge_request: {state_event: :reopen }), method: :put, class: 'btn btn-grouped btn-reopen reopen-mr-link', title: 'Reopen merge request'
+        = link_to 'Reopen', merge_request_path(@merge_request, merge_request: {state_event: :reopen }), method: :put, class: 'btn btn-nr btn-grouped btn-reopen reopen-mr-link', title: 'Reopen merge request'
diff --git a/app/views/projects/notes/_form.html.haml b/app/views/projects/notes/_form.html.haml
index 88e711ab5341d848e3e76270338819d32e970fab..acb6dc52a8e204f7fecfc7d2f70eeabe844041dc 100644
--- a/app/views/projects/notes/_form.html.haml
+++ b/app/views/projects/notes/_form.html.haml
@@ -13,6 +13,6 @@
     .error-alert
 
   .note-form-actions.clearfix
-    = f.submit 'Add Comment', class: "btn btn-create comment-btn btn-grouped js-comment-button"
+    = f.submit 'Add Comment', class: "btn btn-nr btn-create comment-btn btn-grouped js-comment-button"
     = yield(:note_actions)
     %a.btn.btn-cancel.js-close-discussion-note-form Cancel
diff --git a/app/views/projects/show.html.haml b/app/views/projects/show.html.haml
index 9c7a5584da9a1122a09121c940dc26c29da46461..7466a098e24d0ba1e735d307ffc41c17c7a458b2 100644
--- a/app/views/projects/show.html.haml
+++ b/app/views/projects/show.html.haml
@@ -71,7 +71,7 @@
   = render default_project_view
 
 - if current_user
-  - access = user_max_access_in_project(current_user, @project)
+  - access = user_max_access_in_project(current_user.id, @project)
   - if access
     .prepend-top-20.project-footer
       .gray-content-block.footer-block.center
diff --git a/app/views/projects/tree/_tree_content.html.haml b/app/views/projects/tree/_tree_content.html.haml
index 1bc90edd8f0342c35352cd162328c55a14e3f00f..1927883513afbf2a2e0b96e8ea1973a97da658fe 100644
--- a/app/views/projects/tree/_tree_content.html.haml
+++ b/app/views/projects/tree/_tree_content.html.haml
@@ -29,7 +29,7 @@
   - if tree.readme
     = render "projects/tree/readme", readme: tree.readme
 
-- if allowed_tree_edit?
+- if can_edit_tree?
   = render 'projects/blob/upload', title: 'Upload New File', placeholder: 'Upload new file', button_title: 'Upload file', form_path: namespace_project_create_blob_path(@project.namespace, @project, @id), method: :post
   = render 'projects/blob/new_dir'
 
diff --git a/app/views/projects/tree/_tree_header.html.haml b/app/views/projects/tree/_tree_header.html.haml
index 89b072cea923077d2dc9b876c4c22631cfab24c3..3343288ad2b1da800a7ce50eca1176ea2c19ce9d 100644
--- a/app/views/projects/tree/_tree_header.html.haml
+++ b/app/views/projects/tree/_tree_header.html.haml
@@ -11,34 +11,65 @@
         = link_to truncate(title, length: 40), namespace_project_tree_path(@project.namespace, @project, path)
       - else
         = link_to title, '#'
-  - if allowed_tree_edit?
+
+  - if current_user
     %li
-      %span.dropdown
-        %a.dropdown-toggle.btn.btn-sm.add-to-tree{href: '#', "data-toggle" => "dropdown"}
+      - if !on_top_of_branch?
+        %span.btn.btn-sm.add-to-tree.disabled.has_tooltip{title: "You can only add files when you are on a branch", data: { container: 'body' }}
           = icon('plus')
-        %ul.dropdown-menu
-          %li
-            = link_to namespace_project_new_blob_path(@project.namespace, @project, @id), title: 'Create file', id: 'new-file-link' do
-              = icon('pencil fw')
-              New file
-          %li
-            = link_to '#modal-upload-blob', { 'data-target' => '#modal-upload-blob', 'data-toggle' => 'modal'} do
-              = icon('file fw')
-              Upload file
-          %li
-            = link_to '#modal-create-new-dir', { 'data-target' => '#modal-create-new-dir', 'data-toggle' => 'modal'} do
-              = icon('folder fw')
-              New directory
-          %li.divider
-          %li
-            = link_to new_namespace_project_branch_path(@project.namespace, @project) do
-              = icon('code-fork fw')
-              New branch
-          %li
-            = link_to new_namespace_project_tag_path(@project.namespace, @project) do
-              = icon('tags fw')
-              New tag
-  - elsif !on_top_of_branch?
-    %li
-      %span.btn.btn-sm.add-to-tree.disabled.has_tooltip{title: "You can only add files when you are on a branch.", data: {container: 'body'}}
-        = icon('plus')
+      - else
+        %span.dropdown
+          %a.dropdown-toggle.btn.btn-sm.add-to-tree{href: '#', "data-toggle" => "dropdown"}
+            = icon('plus')
+          %ul.dropdown-menu
+            - if can_edit_tree?
+              %li
+                = link_to namespace_project_new_blob_path(@project.namespace, @project, @id) do
+                  = icon('pencil fw')
+                  New file
+              %li
+                = link_to '#modal-upload-blob', { 'data-target' => '#modal-upload-blob', 'data-toggle' => 'modal'} do
+                  = icon('file fw')
+                  Upload file
+              %li
+                = link_to '#modal-create-new-dir', { 'data-target' => '#modal-create-new-dir', 'data-toggle' => 'modal'} do
+                  = icon('folder fw')
+                  New directory
+            - elsif can?(current_user, :fork_project, @project)
+              %li
+                - continue_params = { to:         namespace_project_new_blob_path(@project.namespace, @project, @id),
+                                      notice:     edit_in_new_fork_notice,
+                                      notice_now: edit_in_new_fork_notice_now }
+                - fork_path = namespace_project_fork_path(@project.namespace, @project, namespace_key:  current_user.namespace.id,
+                                                                                        continue:       continue_params)
+                = link_to fork_path, method: :post do
+                  = icon('pencil fw')
+                  New file
+              %li
+                - continue_params = { to:         request.fullpath,
+                                      notice:     edit_in_new_fork_notice + " Try to upload a file again.",
+                                      notice_now: edit_in_new_fork_notice_now }
+                - fork_path = namespace_project_fork_path(@project.namespace, @project, namespace_key:  current_user.namespace.id,
+                                                                                        continue:       continue_params)
+                = link_to fork_path, method: :post do
+                  = icon('file fw')
+                  Upload file
+              %li
+                - continue_params = { to:         request.fullpath,
+                                      notice:     edit_in_new_fork_notice + " Try to create a new directory again.",
+                                      notice_now: edit_in_new_fork_notice_now }
+                - fork_path = namespace_project_fork_path(@project.namespace, @project, namespace_key:  current_user.namespace.id,
+                                                                                        continue:       continue_params)
+                = link_to fork_path, method: :post do
+                  = icon('folder fw')
+                  New directory
+
+            %li.divider
+            %li
+              = link_to new_namespace_project_branch_path(@project.namespace, @project) do
+                = icon('code-fork fw')
+                New branch
+            %li
+              = link_to new_namespace_project_tag_path(@project.namespace, @project) do
+                = icon('tags fw')
+                New tag
diff --git a/app/views/search/results/_issue.html.haml b/app/views/search/results/_issue.html.haml
index ce8ddff955690ea4895580cdb23945e75fd8bd7d..45d700781f3e3d14547268ef9444810112a8e32e 100644
--- a/app/views/search/results/_issue.html.haml
+++ b/app/views/search/results/_issue.html.haml
@@ -6,7 +6,7 @@
   - if issue.description.present?
     .description.term
       = preserve do
-        = search_md_sanitize(markdown(issue.description))
+        = search_md_sanitize(markdown(issue.description, { project: issue.project }))
   %span.light
     #{issue.project.name_with_namespace}
   - if issue.closed?
diff --git a/app/views/shared/_clone_panel.html.haml b/app/views/shared/_clone_panel.html.haml
index edb5778f4240740ef66bbbf4560a3b0074b6e3b7..687a59c270f9f35d5b940aa740ac60b18f453839 100644
--- a/app/views/shared/_clone_panel.html.haml
+++ b/app/views/shared/_clone_panel.html.haml
@@ -1,10 +1,27 @@
 - project = project || @project
-.git-clone-holder.input-group
-  .input-group-addon.git-protocols
-    .input-group-btn
-      = ssh_clone_button(project)
-    .input-group-btn
-      = http_clone_button(project)
+
+.git-clone-holder
+  .btn-group.clone-options
+    %a#clone-dropdown.clone-dropdown-btn.btn{href: '#', 'data-toggle' => 'dropdown'}
+      %span
+        = default_clone_protocol.upcase
+      = icon('angle-down')
+    %ul.dropdown-menu.dropdown-menu-right.clone-options-dropdown
+      %li
+        %a#ssh-selector{href: @project.ssh_url_to_repo}
+          SSH
+      %li
+        %a#http-selector{href: @project.http_url_to_repo}
+          HTTPS
+
   = text_field_tag :project_clone, default_url_to_repo(project), class: "js-select-on-focus form-control", readonly: true
   .input-group-btn
     = clipboard_button(clipboard_target: '#project_clone')
+
+:javascript
+  $('ul.clone-options-dropdown a').on('click',function(e){
+    e.preventDefault();
+    var $this = $(this);
+    $('a.clone-dropdown-btn span').text($this.text());
+    $('#project_clone').val($this.attr('href'));
+  });
diff --git a/app/views/shared/_new_commit_form.html.haml b/app/views/shared/_new_commit_form.html.haml
index 111219f2064c69b8952b38f5e9935138570e5a20..0c8ac48bb58f8d3ced26fbbf7d54f7bb58f61d83 100644
--- a/app/views/shared/_new_commit_form.html.haml
+++ b/app/views/shared/_new_commit_form.html.haml
@@ -1,16 +1,22 @@
 = render 'shared/commit_message_container', placeholder: placeholder
 
-- unless @project.empty_repo?
-  .form-group.branch
-    = label_tag 'new_branch', 'Target branch', class: 'control-label'
-    .col-sm-10
-      = text_field_tag 'new_branch', @new_branch || tree_edit_branch, required: true, class: "form-control js-new-branch"
+- if @project.empty_repo?
+  = hidden_field_tag 'target_branch', @ref
+- else
+  - if can?(current_user, :push_code, @project)
+    .form-group.branch
+      = label_tag 'target_branch', 'Target branch', class: 'control-label'
+      .col-sm-10
+        = text_field_tag 'target_branch', @target_branch || tree_edit_branch, required: true, class: "form-control js-target-branch"
 
-      .js-create-merge-request-container
-        .checkbox
-          - nonce = SecureRandom.hex
-          = label_tag "create_merge_request-#{nonce}" do
-            = check_box_tag 'create_merge_request', 1, true, class: 'js-create-merge-request', id: "create_merge_request-#{nonce}"
-            Start a <strong>new merge request</strong> with these changes
+        .js-create-merge-request-container
+          .checkbox
+            - nonce = SecureRandom.hex
+            = label_tag "create_merge_request-#{nonce}" do
+              = check_box_tag 'create_merge_request', 1, true, class: 'js-create-merge-request', id: "create_merge_request-#{nonce}"
+              Start a <strong>new merge request</strong> with these changes
+  - else
+    = hidden_field_tag 'target_branch', @target_branch || tree_edit_branch
+    = hidden_field_tag 'create_merge_request', 1
 
   = hidden_field_tag 'original_branch', @ref, class: 'js-original-branch'
diff --git a/app/views/votes/_votes_block.html.haml b/app/views/votes/_votes_block.html.haml
index 6071f1484c621f05b316a8b23555d66f1835e276..e16187bb42f8d6f4965cb2a5b54a8daf4427ac34 100644
--- a/app/views/votes/_votes_block.html.haml
+++ b/app/views/votes/_votes_block.html.haml
@@ -1,33 +1,46 @@
 .awards.votes-block
   - votable.notes.awards.grouped_awards.each do |emoji, notes|
     .award{class: (note_active_class(notes, current_user)), title: emoji_author_list(notes, current_user)}
-      .icon{"data-emoji" => "#{emoji}"}
-        = image_tag url_to_emoji(emoji), height: "20px", width: "20px"
+      = emoji_icon(emoji)
       .counter
         = notes.count
 
   - if current_user
-    .dropdown.awards-controls
+    .awards-controls
       %a.add-award{"data-toggle" => "dropdown", "data-target" => "#", "href" => "#"}
         = icon('smile-o')
-      %ul.dropdown-menu.awards-menu
-        - emoji_list.each do |emoji|
-          %li{"data-emoji" => "#{emoji}"}= image_tag url_to_emoji(emoji), height: "20px", width: "20px"
+      .emoji-menu
+        .emoji-menu-content
+          = text_field_tag :emoji_search, "", class: "emoji-search search-input form-control"
+          - AwardEmoji.emoji_by_category.each do |category, emojis|
+            %h5= AwardEmoji::CATEGORIES[category]
+            %ul
+              - emojis.each do |emoji|
+                %li
+                  = emoji_icon(emoji["name"], emoji["unicode"], emoji["aliases"])
 
 - if current_user
   :coffeescript
     post_emoji_url = "#{award_toggle_namespace_project_notes_path(@project.namespace, @project)}"
     noteable_type = "#{votable.class.name.underscore}"
     noteable_id = "#{votable.id}"
-    aliases = #{AwardEmoji::ALIASES.to_json}
-    window.awards_handler = new AwardsHandler(post_emoji_url, noteable_type, noteable_id, aliases)
+    aliases = #{AwardEmoji.aliases.to_json}
 
-    $(".awards-menu li").click (e)->
-      emoji = $(this).data("emoji")
+    window.awards_handler = new AwardsHandler(
+      post_emoji_url,
+      noteable_type,
+      noteable_id,
+      aliases
+    )
+
+    $(".awards").on "click", ".emoji-menu-content li", (e) ->
+      emoji = $(this).find(".emoji-icon").data("emoji")
       awards_handler.addAward(emoji)
 
-    $(".awards").on "click", ".award", (e)->
+    $(".awards").on "click", ".award", (e) ->
       emoji = $(this).find(".icon").data("emoji")
       awards_handler.addAward(emoji)
 
     $(".award").tooltip()
+
+    $(".emoji-menu-content").niceScroll({cursorwidth: "7px", autohidemode: false})
diff --git a/config/gitlab.yml.example b/config/gitlab.yml.example
index db378118f8550d9e0589a4f70717f5e3d38b3f1d..db68b5512b8a79e7ec8c8b9cc3f96f0c2df29be7 100644
--- a/config/gitlab.yml.example
+++ b/config/gitlab.yml.example
@@ -144,6 +144,15 @@ production: &base
     # plain_url: "http://..."     # default: http://www.gravatar.com/avatar/%{hash}?s=%{size}&d=identicon
     # ssl_url:   "https://..."    # default: https://secure.gravatar.com/avatar/%{hash}?s=%{size}&d=identicon
 
+  ## Auxiliary jobs
+  # Periodically executed jobs, to self-heal Gitlab, do external synchronizations, etc.
+  # Please read here for more information: https://github.com/ondrejbartas/sidekiq-cron#adding-cron-job
+  cron_jobs:
+    # Flag stuck CI builds as failed
+    stuck_ci_builds_worker:
+      cron: "0 0 * * *"
+
+
   #
   # 2. GitLab CI settings
   # ==========================
@@ -287,6 +296,15 @@ production: &base
     # arguments, followed by optional 'args' which can be either a hash or an array.
     # Documentation for this is available at http://doc.gitlab.com/ce/integration/omniauth.html
     providers:
+      # See omniauth-cas3 for more configuration details
+      # - { name: 'cas3',
+      #     label: 'cas3',
+      #     args: {
+      #             url: 'https://sso.example.com',
+      #             disable_ssl_verification: false,
+      #             login_url: '/cas/login',
+      #             service_validate_url: '/cas/p3/serviceValidate',
+      #             logout_url: '/cas/logout'} }
       # - { name: 'github',
       #     app_id: 'YOUR_APP_ID',
       #     app_secret: 'YOUR_APP_SECRET',
@@ -324,6 +342,10 @@ production: &base
       #       application_name: 'YOUR_APP_NAME',
       #       application_password: 'YOUR_APP_PASSWORD' } }
 
+    # SSO maximum session duration in seconds. Defaults to CAS default of 8 hours.
+    # cas3:
+    #   session_duration: 28800
+
   # Shared file storage settings
   shared:
     # path: /mnt/gitlab # Default: shared
diff --git a/config/initializers/1_settings.rb b/config/initializers/1_settings.rb
index 63d8ae174365bc7f6613a109a42671745b573191..816cb0c02a91e99756fc1c4d87015fa6dd312589 100644
--- a/config/initializers/1_settings.rb
+++ b/config/initializers/1_settings.rb
@@ -126,6 +126,10 @@ Settings.omniauth['block_auto_created_users'] = true if Settings.omniauth['block
 Settings.omniauth['auto_link_ldap_user'] = false if Settings.omniauth['auto_link_ldap_user'].nil?
 
 Settings.omniauth['providers']  ||= []
+Settings.omniauth['cas3'] ||= Settingslogic.new({})
+Settings.omniauth.cas3['session_duration'] ||= 8.hours
+Settings.omniauth['session_tickets'] ||= Settingslogic.new({})
+Settings.omniauth.session_tickets['cas3'] = 'ticket'
 
 Settings['shared'] ||= Settingslogic.new({})
 Settings.shared['path'] = File.expand_path(Settings.shared['path'] || "shared", Rails.root)
@@ -164,7 +168,7 @@ Settings.gitlab['signin_enabled'] ||= true if Settings.gitlab['signin_enabled'].
 Settings.gitlab['twitter_sharing_enabled'] ||= true if Settings.gitlab['twitter_sharing_enabled'].nil?
 Settings.gitlab['restricted_visibility_levels'] = Settings.send(:verify_constant_array, Gitlab::VisibilityLevel, Settings.gitlab['restricted_visibility_levels'], [])
 Settings.gitlab['username_changing_enabled'] = true if Settings.gitlab['username_changing_enabled'].nil?
-Settings.gitlab['issue_closing_pattern'] = '((?:[Cc]los(?:e[sd]?|ing)|[Ff]ix(?:e[sd]|ing)?|[Rr]esolv(?:e[sd]?|ing)) +(?:(?:issues? +)?%{issue_ref}(?:(?:, *| +and +)?))+)' if Settings.gitlab['issue_closing_pattern'].nil?
+Settings.gitlab['issue_closing_pattern'] = '((?:[Cc]los(?:e[sd]?|ing)|[Ff]ix(?:e[sd]|ing)?|[Rr]esolv(?:e[sd]?|ing)) +(?:(?:issues? +)?%{issue_ref}(?:(?:, *| +and +)?)|([A-Z]*-\d*))+)' if Settings.gitlab['issue_closing_pattern'].nil?
 Settings.gitlab['default_projects_features'] ||= {}
 Settings.gitlab['webhook_timeout'] ||= 10
 Settings.gitlab['max_attachment_size'] ||= 10
@@ -224,6 +228,15 @@ Settings.gravatar['plain_url']  ||= 'http://www.gravatar.com/avatar/%{hash}?s=%{
 Settings.gravatar['ssl_url']    ||= 'https://secure.gravatar.com/avatar/%{hash}?s=%{size}&d=identicon'
 Settings.gravatar['host']         = Settings.get_host_without_www(Settings.gravatar['plain_url'])
 
+#
+# Cron Jobs
+#
+Settings['cron_jobs'] ||= Settingslogic.new({})
+Settings.cron_jobs['stuck_ci_builds_worker'] ||= Settingslogic.new({})
+Settings.cron_jobs['stuck_ci_builds_worker']['cron'] ||= '0 0 * * *'
+Settings.cron_jobs['stuck_ci_builds_worker']['job_class'] = 'StuckCiBuildsWorker'
+
+
 #
 # GitLab Shell
 #
diff --git a/config/initializers/devise.rb b/config/initializers/devise.rb
index 5fb43a86e13d385f5831108859636a28bce56384..d82cfb3ec0c787022f6b61fcab2f5104f0fee8f0 100644
--- a/config/initializers/devise.rb
+++ b/config/initializers/devise.rb
@@ -121,14 +121,14 @@ Devise.setup do |config|
   config.lock_strategy = :failed_attempts
 
   # Defines which key will be used when locking and unlocking an account
-  # config.unlock_keys = [ :email ]
+  config.unlock_keys = [ :email ]
 
   # Defines which strategy will be used to unlock an account.
   # :email = Sends an unlock link to the user email
   # :time  = Re-enables login after a certain amount of time (see :unlock_in below)
   # :both  = Enables both strategies
   # :none  = No unlock strategy. You should handle unlocking by yourself.
-  config.unlock_strategy = :time
+  config.unlock_strategy = :both
 
   # Number of authentication tries before locking an account if lock_strategy
   # is failed attempts.
@@ -241,6 +241,16 @@ Devise.setup do |config|
       # An Array from the configuration will be expanded.
       provider_arguments.concat provider['args']
     when Hash
+      # Add procs for handling SLO
+      if provider['name'] == 'cas3'
+        provider['args'][:on_single_sign_out]  = lambda do |request|
+          ticket = request.params[:session_index]
+          raise "Service Ticket not found." unless Gitlab::OAuth::Session.valid?(:cas3, ticket)
+          Gitlab::OAuth::Session.destroy(:cas3, ticket)
+          true
+        end
+      end
+
       # A Hash from the configuration will be passed as is.
       provider_arguments << provider['args'].symbolize_keys
     end
diff --git a/config/initializers/sidekiq.rb b/config/initializers/sidekiq.rb
index 2e3a71912ef6b26600838c8a35c4e142c648f614..dcf6ce74d96bbd1dc546a6d0934e5a611d7b8cd7 100644
--- a/config/initializers/sidekiq.rb
+++ b/config/initializers/sidekiq.rb
@@ -18,11 +18,12 @@ Sidekiq.configure_server do |config|
     chain.add Gitlab::SidekiqMiddleware::MemoryKiller if ENV['SIDEKIQ_MEMORY_KILLER_MAX_RSS']
   end
 
-  # Sidekiq-cron: load recurring jobs from schedule.yml
-  schedule_file = 'config/schedule.yml'
-  if File.exists?(schedule_file)
-    Sidekiq::Cron::Job.load_from_hash YAML.load_file(schedule_file)
-  end
+  # Sidekiq-cron: load recurring jobs from gitlab.yml
+  # UGLY Hack to get nested hash from settingslogic
+  cron_jobs = JSON.parse(Gitlab.config.cron_jobs.to_json)
+  # UGLY hack: Settingslogic doesn't allow 'class' key
+  cron_jobs.each { |k,v| cron_jobs[k]['class'] = cron_jobs[k].delete('job_class') }
+  Sidekiq::Cron::Job.load_from_hash! cron_jobs
 
   # Database pool should be at least `sidekiq_concurrency` + 2
   # For more info, see: https://github.com/mperham/sidekiq/blob/master/4.0-Upgrade.md
diff --git a/config/routes.rb b/config/routes.rb
index 57be57e3251719ee573f36804f126d96b6552eec..b9242327de1b0ba98ea869accadebd47ba30238f 100644
--- a/config/routes.rb
+++ b/config/routes.rb
@@ -188,7 +188,7 @@ Rails.application.routes.draw do
   namespace :admin do
     resources :users, constraints: { id: /[a-zA-Z.\/0-9_\-]+/ } do
       resources :keys, only: [:show, :destroy]
-      resources :identities, only: [:index, :edit, :update, :destroy]
+      resources :identities, except: [:show]
 
       delete 'stop_impersonation' => 'impersonation#destroy', on: :collection
 
diff --git a/config/schedule.yml b/config/schedule.yml
deleted file mode 100644
index 993a95fef565b87d049e4d6e15e3e0ed7c33ee2e..0000000000000000000000000000000000000000
--- a/config/schedule.yml
+++ /dev/null
@@ -1,10 +0,0 @@
-# Here is a list of jobs that are scheduled to run periodically.
-# We use a UNIX cron notation to specify execution schedule.
-#
-# Please read here for more information:
-# https://github.com/ondrejbartas/sidekiq-cron#adding-cron-job
-
-stuck_ci_builds_worker:
-  cron: "0 0 * * *"
-  class: "StuckCiBuildsWorker"
-  queue: "default"
diff --git a/db/migrate/20151012173029_set_jira_service_api_url.rb b/db/migrate/20151012173029_set_jira_service_api_url.rb
new file mode 100644
index 0000000000000000000000000000000000000000..2af99e0db0b3f3624b7ef7866609a247357addc3
--- /dev/null
+++ b/db/migrate/20151012173029_set_jira_service_api_url.rb
@@ -0,0 +1,50 @@
+class SetJiraServiceApiUrl < ActiveRecord::Migration
+  # This migration can be performed online without errors, but some Jira API calls may be missed
+  # when doing so because api_url is not yet available.
+
+  def build_api_url_from_project_url(project_url, api_version)
+    # this is the exact logic previously used to build the Jira API URL from project_url
+    server = URI(project_url)
+    default_ports = [80, 443].include?(server.port)
+    server_url = "#{server.scheme}://#{server.host}"
+    server_url.concat(":#{server.port}") unless default_ports
+    "#{server_url}/rest/api/#{api_version}"
+  end
+
+  def get_api_version_from_api_url(api_url)
+    match = /\/rest\/api\/(?<api_version>\w+)$/.match(api_url)
+    match && match['api_version']
+  end
+
+  def change
+    reversible do |dir|
+      select_all("SELECT id, properties FROM services WHERE services.type IN ('JiraService')").each do |jira_service|
+        id = jira_service["id"]
+        properties = JSON.parse(jira_service["properties"])
+        properties_was = properties.clone
+
+        dir.up do
+          # remove api_version and set api_url
+          if properties['api_version'].present? && properties['project_url'].present?
+            begin
+              properties['api_url'] ||= build_api_url_from_project_url(properties['project_url'], properties['api_version'])
+            rescue
+              # looks like project_url was not a valid URL. Do nothing.
+            end
+          end
+          properties.delete('api_version') if properties.include?('api_version')
+        end
+
+        dir.down do
+          # remove api_url and set api_version (default to '2')
+          properties['api_version'] ||= get_api_version_from_api_url(properties['api_url']) || '2'
+          properties.delete('api_url') if properties.include?('api_url')
+        end
+
+        if properties != properties_was
+          execute("UPDATE services SET properties = '#{quote_string(properties.to_json)}' WHERE id = #{id}")
+        end
+      end
+    end
+  end
+end
diff --git a/db/migrate/20151203162134_add_build_events_to_services.rb b/db/migrate/20151203162134_add_build_events_to_services.rb
index a84be7db3f15ba2d87f54bdd52560df34021c2af..c5542cb864da8ca5198f8d76dd8ff6fe61d991b5 100644
--- a/db/migrate/20151203162134_add_build_events_to_services.rb
+++ b/db/migrate/20151203162134_add_build_events_to_services.rb
@@ -1,5 +1,5 @@
 class AddBuildEventsToServices < ActiveRecord::Migration
-  def up
+  def change
     add_column :services, :build_events, :boolean, default: false, null: false
     add_column :web_hooks, :build_events, :boolean, default: false, null: false
   end
diff --git a/db/migrate/20151209144329_migrate_ci_web_hooks.rb b/db/migrate/20151209144329_migrate_ci_web_hooks.rb
index 825ba1973ff85a67a7d88fee7a416a94221d2f3e..d7e196e6763d442f4e650584f0378cb770d75c57 100644
--- a/db/migrate/20151209144329_migrate_ci_web_hooks.rb
+++ b/db/migrate/20151209144329_migrate_ci_web_hooks.rb
@@ -10,4 +10,7 @@ class MigrateCiWebHooks < ActiveRecord::Migration
       'JOIN projects ON ci_projects.gitlab_id = projects.id'
     )
   end
+
+  def down
+  end
 end
diff --git a/db/migrate/20151210030143_add_unlock_token_to_user.rb b/db/migrate/20151210030143_add_unlock_token_to_user.rb
new file mode 100644
index 0000000000000000000000000000000000000000..0ea66ba65dfa6df8896b219dcedbb9aac460b9cd
--- /dev/null
+++ b/db/migrate/20151210030143_add_unlock_token_to_user.rb
@@ -0,0 +1,5 @@
+class AddUnlockTokenToUser < ActiveRecord::Migration
+  def change
+    add_column :users, :unlock_token, :string
+  end
+end
diff --git a/db/migrate/20151210125928_add_ci_to_project.rb b/db/migrate/20151210125928_add_ci_to_project.rb
index 8a65abab636bd9895cb93e913414275517326c08..8c167f64a2b59444c94a5b8a1f914a252e44aec1 100644
--- a/db/migrate/20151210125928_add_ci_to_project.rb
+++ b/db/migrate/20151210125928_add_ci_to_project.rb
@@ -1,5 +1,5 @@
 class AddCiToProject < ActiveRecord::Migration
-  def up
+  def change
     add_column :projects, :ci_id, :integer
     add_column :projects, :builds_enabled, :boolean, default: true, null: false
     add_column :projects, :shared_runners_enabled, :boolean, default: true, null: false
diff --git a/db/migrate/20151210125929_add_project_id_to_ci.rb b/db/migrate/20151210125929_add_project_id_to_ci.rb
index 5d1cf54357673f65f3c0d084bc39d8127453e2db..84273591fa2ede4f606e2ab9cae2418330e00cf1 100644
--- a/db/migrate/20151210125929_add_project_id_to_ci.rb
+++ b/db/migrate/20151210125929_add_project_id_to_ci.rb
@@ -1,5 +1,5 @@
 class AddProjectIdToCi < ActiveRecord::Migration
-  def up
+  def change
     add_column :ci_builds, :gl_project_id, :integer
     add_column :ci_runner_projects, :gl_project_id, :integer
     add_column :ci_triggers, :gl_project_id, :integer
diff --git a/db/migrate/20151210125930_migrate_ci_to_project.rb b/db/migrate/20151210125930_migrate_ci_to_project.rb
index 7527899786227161b404102d9e7a97990551027d..c32c7feb1931443f5e28b1ee0d56eae5cbe71674 100644
--- a/db/migrate/20151210125930_migrate_ci_to_project.rb
+++ b/db/migrate/20151210125930_migrate_ci_to_project.rb
@@ -14,6 +14,10 @@ class MigrateCiToProject < ActiveRecord::Migration
     migrate_ci_service
   end
 
+  def down
+    # We can't reverse the data
+  end
+
   def migrate_project_id_for_table(table)
     subquery = "SELECT gitlab_id FROM ci_projects WHERE ci_projects.id = #{table}.project_id"
     execute("UPDATE #{table} SET gl_project_id=(#{subquery}) WHERE gl_project_id IS NULL")
diff --git a/db/migrate/20151210125931_add_index_to_ci_tables.rb b/db/migrate/20151210125931_add_index_to_ci_tables.rb
index 9fedb5d612ce3c801487b761de65207336a0af4f..5e129c9303d9b0bece0d8fc36100682f8a8a969f 100644
--- a/db/migrate/20151210125931_add_index_to_ci_tables.rb
+++ b/db/migrate/20151210125931_add_index_to_ci_tables.rb
@@ -1,5 +1,5 @@
 class AddIndexToCiTables < ActiveRecord::Migration
-  def up
+  def change
     add_index :ci_builds, :gl_project_id
     add_index :ci_runner_projects, :gl_project_id
     add_index :ci_triggers, :gl_project_id
diff --git a/db/migrate/20151210125932_drop_null_for_ci_tables.rb b/db/migrate/20151210125932_drop_null_for_ci_tables.rb
index 0b007430b0c17168447bc51f80059779f501764c..c520c2ed56f67e2f08d91fa29174d12bcb413ece 100644
--- a/db/migrate/20151210125932_drop_null_for_ci_tables.rb
+++ b/db/migrate/20151210125932_drop_null_for_ci_tables.rb
@@ -1,5 +1,5 @@
 class DropNullForCiTables < ActiveRecord::Migration
-  def up
+  def change
     remove_index :ci_variables, :project_id
     remove_index :ci_runner_projects, :project_id
     change_column_null :ci_triggers, :project_id, true
diff --git a/db/migrate/20151224123230_rename_emojis.rb b/db/migrate/20151224123230_rename_emojis.rb
new file mode 100644
index 0000000000000000000000000000000000000000..62d921dfdcce3e26b7efd0afd2a3dd192bddeead
--- /dev/null
+++ b/db/migrate/20151224123230_rename_emojis.rb
@@ -0,0 +1,15 @@
+# Migration type: online without errors (works on previous version and new one)
+class RenameEmojis < ActiveRecord::Migration
+  def up
+    # Renames aliases to main names
+    execute("UPDATE notes SET note ='thumbsup' WHERE is_award = true AND note = '+1'")
+    execute("UPDATE notes SET note ='thumbsdown' WHERE is_award = true AND note = '-1'")
+    execute("UPDATE notes SET note ='poop' WHERE is_award = true AND note = 'shit'")
+  end
+
+  def down
+    execute("UPDATE notes SET note ='+1' WHERE is_award = true AND note = 'thumbsup'")
+    execute("UPDATE notes SET note ='-1' WHERE is_award = true AND note = 'thumbsdown'")
+    execute("UPDATE notes SET note ='shit' WHERE is_award = true AND note = 'poop'")
+  end
+end
diff --git a/db/schema.rb b/db/schema.rb
index 0167e30ff8b90658ddd9a0796d3c5720a3be376a..0d53105b0570a9239950857b3c1cd84ec3942376 100644
--- a/db/schema.rb
+++ b/db/schema.rb
@@ -11,7 +11,7 @@
 #
 # It's strongly recommended that you check this file into your version control system.
 
-ActiveRecord::Schema.define(version: 20151210125932) do
+ActiveRecord::Schema.define(version: 20151224123230) do
 
   # These are extensions that must be enabled in order to support this database
   enable_extension "plpgsql"
@@ -837,6 +837,7 @@ ActiveRecord::Schema.define(version: 20151210125932) do
     t.integer  "consumed_timestep"
     t.integer  "layout",                     default: 0
     t.boolean  "hide_project_limit",         default: false
+    t.string   "unlock_token"
   end
 
   add_index "users", ["admin"], name: "index_users_on_admin", using: :btree
diff --git a/doc/api/projects.md b/doc/api/projects.md
index 658e65c6f01c91ba4e61e8ca1269c931f94653f7..0ca81ffd49ee1b39636a9d9045d2e6d8022523b6 100644
--- a/doc/api/projects.md
+++ b/doc/api/projects.md
@@ -118,6 +118,16 @@ Parameters:
       "path": "brightbox",
       "updated_at": "2013-09-30T13:46:02Z"
     },
+    "permissions": {
+      "project_access": {
+        "access_level": 10,
+        "notification_level": 3
+      },
+      "group_access": {
+        "access_level": 50,
+        "notification_level": 3
+      }
+    },
     "archived": false,
     "avatar_url": null
   }
diff --git a/doc/ci/README.md b/doc/ci/README.md
index aef6e69b7a6e6053945163212c3d50a4af188906..a1f5513d88e5079e5c919ce13da55ae3ae29b0d8 100644
--- a/doc/ci/README.md
+++ b/doc/ci/README.md
@@ -25,10 +25,11 @@
 
 ### Examples
 
-* [Test and deploy Ruby applications to Heroku](examples/test-and-deploy-ruby-application-to-heroku.md)
-* [Test and deploy Python applications to Heroku](examples/test-and-deploy-python-application-to-heroku.md)
-* [Test Clojure applications](examples/test-clojure-application.md)
-* Help your favorite programming language and GitLab by sending a merge request with a guide for that language.
++ [The .gitlab-ci.yml file for GitLab itself](https://gitlab.com/gitlab-org/gitlab-ce/blob/master/.gitlab-ci.yml)
++ [Test and deploy Ruby applications to Heroku](examples/test-and-deploy-ruby-application-to-heroku.md)
++ [Test and deploy Python applications to Heroku](examples/test-and-deploy-python-application-to-heroku.md)
++ [Test Clojure applications](examples/test-clojure-application.md)
++ Help your favorite programming language and GitLab by sending a merge request with a guide for that language.
 
 ### Administrator documentation
 
diff --git a/doc/integration/README.md b/doc/integration/README.md
index eff39a626ae6205a122558fd5f8990882d930b04..6263353851f3cc5312105afd5bedbc6e16e42be9 100644
--- a/doc/integration/README.md
+++ b/doc/integration/README.md
@@ -4,10 +4,12 @@ GitLab integrates with multiple third-party services to allow external issue tra
 
 See the documentation below for details on how to configure these services.
 
+- [Jira](jira.md) Integrate with the JIRA issue tracker
 - [External issue tracker](external-issue-tracker.md) Redmine, JIRA, etc.
 - [LDAP](ldap.md) Set up sign in via LDAP
 - [OmniAuth](omniauth.md) Sign in via Twitter, GitHub, GitLab, and Google via OAuth.
 - [SAML](saml.md) Configure GitLab as a SAML 2.0 Service Provider
+- [CAS](cas.md) Configure GitLab to sign in using CAS
 - [Slack](slack.md) Integrate with the Slack chat service
 - [OAuth2 provider](oauth_provider.md) OAuth2 application creation
 - [Gmail actions buttons](gmail_action_buttons_for_gitlab.md) Adds GitLab actions to messages
diff --git a/doc/integration/cas.md b/doc/integration/cas.md
new file mode 100644
index 0000000000000000000000000000000000000000..e6b2071f193cd5ca5e424960f4ac9a198de7fbcd
--- /dev/null
+++ b/doc/integration/cas.md
@@ -0,0 +1,62 @@
+# CAS OmniAuth Provider
+
+To enable the CAS OmniAuth provider you must register your application with your CAS instance. This requires the service URL GitLab will supply to CAS. It should be something like: `https://gitlab.example.com:443/users/auth/cas3/callback?url`. By default handling for SLO is enabled, you only need to configure CAS for backchannel logout.
+
+1.  On your GitLab server, open the configuration file.
+
+    For omnibus package:
+
+    ```sh
+      sudo editor /etc/gitlab/gitlab.rb
+    ```
+
+    For installations from source:
+
+    ```sh
+      cd /home/git/gitlab
+
+      sudo -u git -H editor config/gitlab.yml
+    ```
+
+1.  See [Initial OmniAuth Configuration](omniauth.md#initial-omniauth-configuration) for initial settings.
+
+1.  Add the provider configuration:
+
+    For omnibus package:
+
+    ```ruby
+      gitlab_rails['omniauth_providers'] = [
+        {
+          name: "cas3",
+          label: "cas",
+          args: {
+                  url: 'CAS_SERVER',
+                  login_url: '/CAS_PATH/login',
+                  service_validate_url: '/CAS_PATH/p3/serviceValidate',
+                  logout_url: '/CAS_PATH/logout'} }
+          }
+        }
+      ]
+    ```
+
+    For installations from source:
+
+    ```
+      - { name: 'cas3',
+          label: 'cas',
+          args: {
+                  url: 'CAS_SERVER',
+                  login_url: '/CAS_PATH/login',
+                  service_validate_url: '/CAS_PATH/p3/serviceValidate',
+                  logout_url: '/CAS_PATH/logout'} }
+    ```
+
+1.  Change 'CAS_PATH' to the root of your CAS instance (ie. `cas`).
+
+1.  If your CAS instance does not use default TGC lifetimes, update the `cas3.session_duration` to at least the current TGC maximum lifetime. To explicitly disable SLO, regardless of CAS settings, set this to 0.
+
+1.  Save the configuration file.
+
+1.  Restart GitLab for the changes to take effect.
+
+On the sign in page there should now be a CAS tab in the sign in form.
diff --git a/doc/integration/jira.md b/doc/integration/jira.md
new file mode 100644
index 0000000000000000000000000000000000000000..624601d0faccb8e0192d7d7865168a9da0798255
--- /dev/null
+++ b/doc/integration/jira.md
@@ -0,0 +1,113 @@
+# GitLab Jira integration
+
+GitLab can be configured to interact with Jira.
+Configuration happens via username and password.
+Connecting to a Jira server via CAS is not possible.
+
+Each project can be configured to connect to a different Jira instance, configuration is explained [here](#configuration).
+If you have one Jira instance you can pre-fill the settings page with a default template. To configure the template [see external issue tracker document](external-issue-tracker.md#service-template)).
+
+Once the project is connected to Jira, you can reference and close the issues in Jira directly from GitLab.
+
+
+## Table of Contents
+
+* [Referencing Jira Issues from GitLab](#referencing-jira-issues)
+* [Closing Jira Issues from GitLab](#closing-jira-issues)
+* [Configuration](#configuration)
+
+### Referencing Jira Issues
+
+When GitLab project has Jira issue tracker configured and enabled, mentioning Jira issue in GitLab will automatically add a comment in Jira issue with the link back to GitLab. This means that in comments in merge requests and commits referencing an issue, eg. `PROJECT-7`, will add a comment in Jira issue in the format:
+
+
+```
+ USER mentioned this issue in LINK_TO_THE_MENTION
+```
+
+* `USER` A user that mentioned the issue. This is the link to the user profile in GitLab.
+* `LINK_TO_THE_MENTION` Link to the origin of mention with a name of the entity where Jira issue was mentioned.
+Can be commit or merge request.
+
+
+![example of mentioning or closing the Jira issue](jira_issue_reference.png)
+
+
+### Closing Jira Issues
+
+Jira issues can be closed directly from GitLab by using trigger words, eg. `Resolves PROJECT-1`, `Closes PROJECT-1` or `Fixes PROJECT-1`, in commits and merge requests.
+When a commit which contains the trigger word in the commit message is pushed, GitLab will add a comment in the mentioned Jira issue.
+
+For example, for project named PROJECT in Jira, we implemented a new feature and created a merge request in GitLab.
+
+This feature was requested in Jira issue PROJECT-7. Merge request in GitLab contains the improvement and in merge request description we say that this merge request `Closes PROJECT-7` issue.
+
+Once this merge request is merged, Jira issue will be automatically closed with a link to the commit that resolved the issue.
+
+![A Git commit that causes the Jira issue to be closed](merge_request_close_jira.png)
+
+
+![The GitLab integration user leaves a comment on Jira](jira_service_close_issue.png)
+
+
+## Configuration
+
+### Configuring JIRA
+
+We need to create a user in JIRA which will have access to all projects that need to integrate with GitLab.
+Login to your JIRA instance as admin and under Administration go to User Management and create a new user.
+As an example, we'll create a user named `gitlab` and add it to `jira-developers` group.
+
+**It is important that the user `gitlab` has write-access to projects in JIRA**
+
+### Configuring GitLab
+
+### GitLab 7.8 EE and up with JIRA v6.x
+
+To enable JIRA integration in a project, navigate to the project Settings page and go to Services. Here you will find JIRA.
+
+Fill in the required details on the page:
+
+![Jira service page](jira_service_page.png)
+
+* `description` A name for the issue tracker (to differentiate between instances, for instance).
+* `project url` The URL to the JIRA project which is being linked to this GitLab project.
+* `issues url` The URL to the JIRA project issues overview for the project that is linked to this GitLab project.
+* `new issue url` This is the URL to create a new issue in JIRA for the project linked to this GitLab project.
+* `api url` The base URL of the JIRA API. It may be omitted, in which case GitLab will automatically use API version `2` based on the `project url`, i.e. `https://jira.example.com/rest/api/2`.
+* `username` The username of the user created in [configuring JIRA step](#configuring-jira).
+* `password` The password of the user created in [configuring JIRA step](#configuring-jira).
+* `Jira issue transition` This is the id of a transition that moves issues to a closed state. You can find this number under [JIRA workflow administration, see screenshot](jira_workflow_screenshot.png).  By default, this id is `2`. (In the example image, this is `2` as well)
+
+After saving the configuration, your GitLab project will be able to interact with the linked JIRA project.
+
+
+### GitLab 6.x-7.7 with JIRA v6.x
+
+**Note: GitLab 7.8 and up contain various integration improvements. We strongly recommend upgrading.**
+
+
+In `gitlab.yml` enable [JIRA issue tracker section by uncommenting the lines](https://gitlab.com/subscribers/gitlab-ee/blob/6-8-stable-ee/config/gitlab.yml.example#L111-115).
+This will make sure that all issues within GitLab are pointing to the JIRA issue tracker.
+
+We can also enable JIRA service that will allow us to interact with JIRA issues.
+
+For example, we can close issues in JIRA by a commit in GitLab.
+
+Go to project settings page and fill in the project name for the JIRA project:
+
+![Set the JIRA project name in GitLab to 'NEW'](jira_project_name.png)
+
+Next, go to the services page and find JIRA.
+
+![Jira services page](jira_service.png)
+
+1. Tick the active check box to enable the service.
+1. Supply the url to JIRA server, for example http://jira.sample
+1. Supply the username of a user we created under `Configuring JIRA` section, for example `gitlab`
+1. Supply the password of the user
+1. Optional: supply the JIRA api version, default is version
+1. Optional: supply the JIRA issue transition ID (issue transition to closed). This is dependant on JIRA settings, default is 2
+1. Save
+
+Now we should be able to interact with JIRA issues.
diff --git a/doc/integration/jira_issue_reference.png b/doc/integration/jira_issue_reference.png
new file mode 100644
index 0000000000000000000000000000000000000000..15739a22dc7151af663316c1d44e8fcda704ce29
Binary files /dev/null and b/doc/integration/jira_issue_reference.png differ
diff --git a/doc/integration/jira_project_name.png b/doc/integration/jira_project_name.png
new file mode 100644
index 0000000000000000000000000000000000000000..5986fdb63fb8727b339b69d7fa6b64d3ef5f4b17
Binary files /dev/null and b/doc/integration/jira_project_name.png differ
diff --git a/doc/integration/jira_service.png b/doc/integration/jira_service.png
new file mode 100644
index 0000000000000000000000000000000000000000..1f6628c43719edd55d415f80d28d8d4423002586
Binary files /dev/null and b/doc/integration/jira_service.png differ
diff --git a/doc/integration/jira_service_close_issue.png b/doc/integration/jira_service_close_issue.png
new file mode 100644
index 0000000000000000000000000000000000000000..67dfc6144c44f0643e1373bef9961bf0c3a458fb
Binary files /dev/null and b/doc/integration/jira_service_close_issue.png differ
diff --git a/doc/integration/jira_service_page.png b/doc/integration/jira_service_page.png
new file mode 100644
index 0000000000000000000000000000000000000000..69ec44e826fb82702103f7cf1fd4299084e24151
Binary files /dev/null and b/doc/integration/jira_service_page.png differ
diff --git a/doc/integration/jira_workflow_screenshot.png b/doc/integration/jira_workflow_screenshot.png
new file mode 100644
index 0000000000000000000000000000000000000000..8635a32eb6874fa64bc53ba671794c20e9df2f00
Binary files /dev/null and b/doc/integration/jira_workflow_screenshot.png differ
diff --git a/features/project/commits/branches.feature b/features/project/commits/branches.feature
index 5103ca1294756abebba39fd1c97034612ff274ec..2c17d32154a9788bcb168213358aa305e506c154 100644
--- a/features/project/commits/branches.feature
+++ b/features/project/commits/branches.feature
@@ -25,6 +25,7 @@ Feature: Project Commits Branches
     And I click branch 'improve/awesome' delete link
     Then I should not see branch 'improve/awesome'
 
+  @javascript
   Scenario: I create a branch with invalid name
     Given I visit project branches page
     And I click new branch link
diff --git a/features/project/create.feature b/features/project/create.feature
index a86079143e58ad86233cd5c37ff71de859d8def2..27136798e36d14f9b2b55a306f8b8bc30b189297 100644
--- a/features/project/create.feature
+++ b/features/project/create.feature
@@ -1,3 +1,4 @@
+@project-create
 Feature: Project Create
   In order to get access to project sections
   A user with ability to create a project
diff --git a/features/project/issues/award_emoji.feature b/features/project/issues/award_emoji.feature
index 0ce99e855c6f91b0c8d0c16af8f065963647146e..9a06fdc2ee6eb5ea0a40a84ea441a31cc3b5ebdc 100644
--- a/features/project/issues/award_emoji.feature
+++ b/features/project/issues/award_emoji.feature
@@ -13,7 +13,18 @@ Feature: Award Emoji
     Then I have award added
     And I can remove it by clicking to icon
 
+  @javascript
+  Scenario: I can see the list of emoji categories
+    Given I click to emoji-picker
+    Then I can see the activity and food categories
+
+  @javascript
+  Scenario: I can search emoji
+    Given I click to emoji-picker
+    And I search "hand"
+    Then I see search result for "hand"
+
   @javascript
   Scenario: I add award emoji using regular comment
-  Given I leave comment with a single emoji
-  Then I have award added
+    Given I leave comment with a single emoji
+    Then I have award added
diff --git a/features/project/merge_requests/accept.feature b/features/project/merge_requests/accept.feature
index d5e4f2b0bd8c4755d616fd5a76b44574cd1d9be1..330ec8ae0fe552cc9b4480525724626135a584d8 100644
--- a/features/project/merge_requests/accept.feature
+++ b/features/project/merge_requests/accept.feature
@@ -12,6 +12,14 @@ Feature: Project Merge Requests Acceptance
     Then I should see merge request merged
     And I should not see the Remove Source Branch button
 
+  @javascript
+  Scenario: Accepting the Merge Request when URL has an anchor
+    Given I am on the Merge Request detail with note anchor page
+    When I click on "Remove source branch" option
+    And I click on Accept Merge Request
+    Then I should see merge request merged
+    And I should not see the Remove Source Branch button
+
   @javascript
   Scenario: Accepting the Merge Request without removing the source branch
     Given I am on the Merge Request detail page
diff --git a/features/project/service.feature b/features/project/service.feature
index ff3e7a0b38e6bd063878f3246d9806c8aa876275..3a7b830852489d2560619a4aabc6203023827cff 100644
--- a/features/project/service.feature
+++ b/features/project/service.feature
@@ -55,6 +55,12 @@ Feature: Project Services
     And I fill email on push settings
     Then I should see email on push service settings saved
 
+  Scenario: Activate JIRA service
+    When I visit project "Shop" services page
+    And I click jira service link
+    And I fill jira settings
+    Then I should see jira service settings saved
+
   Scenario: Activate Irker (IRC Gateway) service
     When I visit project "Shop" services page
     And I click Irker service link
diff --git a/features/project/source/browse_files.feature b/features/project/source/browse_files.feature
index 02159ee3776e9dafa46905e7f0bb248946b31ba8..a8c276b949ea51f9b928c72acdf6d5b4fd414e0b 100644
--- a/features/project/source/browse_files.feature
+++ b/features/project/source/browse_files.feature
@@ -24,6 +24,12 @@ Feature: Project Source Browse Files
     Given I click on "New file" link in repo
     Then I can see new file page
 
+  Scenario: I can create file when I don't have write access
+    Given I don't have write access
+    And I click on "New file" link in repo
+    Then I should see a notice about a new fork having been created
+    Then I can see new file page
+
   @javascript
   Scenario: I can create and commit file
     Given I click on "New file" link in repo
@@ -34,6 +40,17 @@ Feature: Project Source Browse Files
     Then I am redirected to the new file
     And I should see its new content
 
+  @javascript
+  Scenario: I can create and commit file when I don't have write access
+    Given I don't have write access
+    And I click on "New file" link in repo
+    And I edit code
+    And I fill the new file name
+    And I fill the commit message
+    And I click on "Commit Changes"
+    Then I am redirected to the fork's new merge request page
+    And I can see the new commit message
+
   @javascript
   Scenario: I can create and commit file with new lines at the end of file
     Given I click on "New file" link in repo
@@ -45,6 +62,17 @@ Feature: Project Source Browse Files
     And I click button "Edit"
     And I should see its content with new lines preserved at end of file
 
+  @javascript
+  Scenario: I can create and commit file and specify new branch
+    Given I click on "New file" link in repo
+    And I edit code
+    And I fill the new file name
+    And I fill the commit message
+    And I fill the new branch name
+    And I click on "Commit Changes"
+    Then I am redirected to the new merge request page
+    And I should see its new content
+
   @javascript
   Scenario: I can upload file and commit
     Given I click on "Upload file" link in repo
@@ -56,6 +84,19 @@ Feature: Project Source Browse Files
     And I am redirected to the new merge request page
     And I can see the new commit message
 
+  @javascript
+  Scenario: I can upload file and commit when I don't have write access
+    Given I don't have write access
+    And I click on "Upload file" link in repo
+    Then I should see a notice about a new fork having been created
+    When I click on "Upload file" link in repo
+    And I upload a new text file
+    And I fill the upload file commit message
+    And I click on "Upload file"
+    Then I can see the new text file
+    And I am redirected to the fork's new merge request page
+    And I can see the new commit message
+
   @javascript
   Scenario: I can replace file and commit
     Given I click on ".gitignore" file in repo
@@ -68,15 +109,19 @@ Feature: Project Source Browse Files
     And I can see the replacement commit message
 
   @javascript
-  Scenario: I can create and commit file and specify new branch
-    Given I click on "New file" link in repo
-    And I edit code
-    And I fill the new file name
-    And I fill the commit message
-    And I fill the new branch name
-    And I click on "Commit Changes"
-    Then I am redirected to the new merge request page
-    And I should see its new content
+  Scenario: I can replace file and commit when I don't have write access
+    Given I don't have write access
+    And I click on ".gitignore" file in repo
+    And I see the ".gitignore"
+    And I click on "Replace"
+    Then I should see a notice about a new fork having been created
+    When I click on "Replace"
+    And I replace it with a text file
+    And I fill the replace file commit message
+    And I click on "Replace file"
+    Then I can see the new text file
+    And I am redirected to the fork's new merge request page
+    And I can see the replacement commit message
 
   @javascript
   Scenario: I can create file in empty repo
@@ -117,6 +162,14 @@ Feature: Project Source Browse Files
     And I click button "Edit"
     Then I can edit code
 
+  @javascript
+  Scenario: I can edit file when I don't have write access
+    Given I don't have write access
+    And I click on ".gitignore" file in repo
+    And I click button "Edit"
+    Then I should see a notice about a new fork having been created
+    And I can edit code
+
   Scenario: If the file is binary the edit link is hidden
     Given I visit a binary file in the repo
     Then I cannot see the edit button
@@ -131,6 +184,17 @@ Feature: Project Source Browse Files
     Then I am redirected to the ".gitignore"
     And I should see its new content
 
+  @javascript
+  Scenario: I can edit and commit file when I don't have write access
+    Given I don't have write access
+    And I click on ".gitignore" file in repo
+    And I click button "Edit"
+    And I edit code
+    And I fill the commit message
+    And I click on "Commit Changes"
+    Then I am redirected to the fork's new merge request page
+    And I can see the new commit message
+
   @javascript
   Scenario: I can edit and commit file to new branch
     Given I click on ".gitignore" file in repo
@@ -161,6 +225,17 @@ Feature: Project Source Browse Files
     And I click on "Create directory"
     Then I am redirected to the new merge request page
 
+  @javascript
+  Scenario: I can create directory in repo when I don't have write access
+    Given I don't have write access
+    When I click on "New directory" link in repo
+    Then I should see a notice about a new fork having been created
+    When I click on "New directory" link in repo
+    And I fill the new directory name
+    And I fill the commit message
+    And I click on "Create directory"
+    Then I am redirected to the fork's new merge request page
+
   @javascript
   Scenario: I attempt to create an existing directory
     When I click on "New directory" link in repo
@@ -188,6 +263,19 @@ Feature: Project Source Browse Files
     Then I am redirected to the files URL
     And I don't see the ".gitignore"
 
+  @javascript
+  Scenario: I can delete file and commit when I don't have write access
+    Given I don't have write access
+    And I click on ".gitignore" file in repo
+    And I see the ".gitignore"
+    And I click on "Delete"
+    Then I should see a notice about a new fork having been created
+    When I click on "Delete"
+    And I fill the commit message
+    And I click on "Delete file"
+    Then I am redirected to the fork's new merge request page
+    And I can see the new commit message
+
   Scenario: I can browse directory with Browse Dir
     Given I click on files directory
     And I click on History link
diff --git a/features/project/star.feature b/features/project/star.feature
index a45f9c470ea8921eb2f023899752af0af6e83d38..618f44fe6dc31cc2a4ce916debbcca2a85cfc233 100644
--- a/features/project/star.feature
+++ b/features/project/star.feature
@@ -1,3 +1,4 @@
+@project-stars
 Feature: Project Star
   Scenario: New projects have 0 stars
     Given public project "Community"
diff --git a/features/steps/project/commits/branches.rb b/features/steps/project/commits/branches.rb
index 338f5e8d3ee66ce7c2ed50bf4f3695b2e7a6e614..0a42931147dc1ee7f78562f97c6fe1172ec1fec1 100644
--- a/features/steps/project/commits/branches.rb
+++ b/features/steps/project/commits/branches.rb
@@ -61,7 +61,8 @@ class Spinach::Features::ProjectCommitsBranches < Spinach::FeatureSteps
   end
 
   step 'I should see new an error that branch is invalid' do
-    expect(page).to have_content 'Branch name invalid'
+    expect(page).to have_content 'Branch name is invalid'
+    expect(page).to have_content "can't contain spaces"
   end
 
   step 'I should see new an error that ref is invalid' do
diff --git a/features/steps/project/create.rb b/features/steps/project/create.rb
index f90218f379162380cdc78d46168dd27ca63a7b72..8a0e8fc2b6c8998937c4140558cc882e877d5a20 100644
--- a/features/steps/project/create.rb
+++ b/features/steps/project/create.rb
@@ -26,7 +26,8 @@ class Spinach::Features::ProjectCreate < Spinach::FeatureSteps
   end
 
   step 'I click on HTTP' do
-    click_button 'HTTP'
+    find('#clone-dropdown').click
+    find('#http-selector').click
   end
 
   step 'Remote url should update to http link' do
@@ -34,7 +35,8 @@ class Spinach::Features::ProjectCreate < Spinach::FeatureSteps
   end
 
   step 'If I click on SSH' do
-    click_button 'SSH'
+    find('#clone-dropdown').click
+    find('#ssh-selector').click
   end
 
   step 'Remote url should update to ssh link' do
diff --git a/features/steps/project/issues/award_emoji.rb b/features/steps/project/issues/award_emoji.rb
index 325eaf2ea6a5834ea388eed6e1244e152b372a88..a7e1539881906c38efc859fa7e86438383b0123e 100644
--- a/features/steps/project/issues/award_emoji.rb
+++ b/features/steps/project/issues/award_emoji.rb
@@ -15,8 +15,8 @@ class Spinach::Features::AwardEmoji < Spinach::FeatureSteps
   end
 
   step 'I click to emoji in the picker' do
-    page.within '.awards-menu' do
-      page.first('img').click
+    page.within '.emoji-menu' do
+      page.first('.emoji-icon').click
     end
   end
 
@@ -27,6 +27,13 @@ class Spinach::Features::AwardEmoji < Spinach::FeatureSteps
     end
   end
 
+  step 'I can see the activity and food categories' do
+    page.within '.emoji-menu' do
+      expect(page).to_not have_selector 'Activity'
+      expect(page).to_not have_selector 'Food'
+    end
+  end
+
   step 'I have award added' do
     page.within '.awards' do
       expect(page).to have_selector '.award'
@@ -45,4 +52,16 @@ class Spinach::Features::AwardEmoji < Spinach::FeatureSteps
       click_button 'Add Comment'
     end
   end
+
+  step 'I search "hand"' do
+    page.within('.emoji-menu-content') do
+      fill_in 'emoji_search', with: 'hand'
+    end
+  end
+
+  step 'I see search result for "hand"' do
+    page.within '.emoji-menu-content' do
+      expect(page).to have_selector '[data-emoji="raised_hand"]'
+    end
+  end
 end
diff --git a/features/steps/project/merge_requests/acceptance.rb b/features/steps/project/merge_requests/acceptance.rb
index 383c055c4efeb7926a7164e65eb557afc4b0563e..2685f5fd6b4b5f891fe4fb75afb7128d55fbd0f2 100644
--- a/features/steps/project/merge_requests/acceptance.rb
+++ b/features/steps/project/merge_requests/acceptance.rb
@@ -6,6 +6,10 @@ class Spinach::Features::ProjectMergeRequestsAcceptance < Spinach::FeatureSteps
     visit merge_request_path(@merge_request)
   end
 
+  step 'I am on the Merge Request detail with note anchor page' do
+    visit merge_request_path(@merge_request, anchor: 'note_123')
+  end
+
   step 'I click on "Remove source branch" option' do
     check('Remove source branch')
   end
diff --git a/features/steps/project/services.rb b/features/steps/project/services.rb
index ed3957ca87364b9b3cbd75b1f62b3ca2d10333b0..536199ddb4fd7c25f766b7a93b5a74dd992490e0 100644
--- a/features/steps/project/services.rb
+++ b/features/steps/project/services.rb
@@ -173,6 +173,24 @@ class Spinach::Features::ProjectServices < Spinach::FeatureSteps
     expect(find_field('Sound').find('option[selected]').value).to eq 'bike'
   end
 
+  step 'I click jira service link' do
+    click_link 'JIRA'
+  end
+
+  step 'I fill jira settings' do
+    fill_in 'Project url', with: 'http://jira.example'
+    fill_in 'Username', with: 'gitlab'
+    fill_in 'Password', with: 'gitlab'
+    fill_in 'Api url', with: 'http://jira.example/rest/api/2'
+    click_button 'Save'
+  end
+
+  step 'I should see jira service settings saved' do
+    expect(find_field('Project url').value).to eq 'http://jira.example'
+    expect(find_field('Username').value).to eq 'gitlab'
+    expect(find_field('Api url').value).to eq 'http://jira.example/rest/api/2'
+  end
+
   step 'I click Atlassian Bamboo CI service link' do
     click_link 'Atlassian Bamboo CI'
   end
diff --git a/features/steps/project/source/browse_files.rb b/features/steps/project/source/browse_files.rb
index 0c6df18ce2e46dd49925f8084e33fa48fe1ee3d2..d08935aa1010a9f10be706ba03f8e87edba1d53d 100644
--- a/features/steps/project/source/browse_files.rb
+++ b/features/steps/project/source/browse_files.rb
@@ -5,6 +5,12 @@ class Spinach::Features::ProjectSourceBrowseFiles < Spinach::FeatureSteps
   include SharedPaths
   include RepoHelpers
 
+  step "I don't have write access" do
+    @project = create(:project, name: "Other Project", path: "other-project")
+    @project.team << [@user, :reporter]
+    visit namespace_project_tree_path(@project.namespace, @project, root_ref)
+  end
+
   step 'I should see files from repository' do
     expect(page).to have_content "VERSION"
     expect(page).to have_content ".gitignore"
@@ -75,7 +81,7 @@ class Spinach::Features::ProjectSourceBrowseFiles < Spinach::FeatureSteps
   end
 
   step 'I fill the new branch name' do
-    fill_in :new_branch, with: 'new_branch_name', visible: true
+    fill_in :target_branch, with: 'new_branch_name', visible: true
   end
 
   step 'I fill the new file name with an illegal name' do
@@ -87,7 +93,7 @@ class Spinach::Features::ProjectSourceBrowseFiles < Spinach::FeatureSteps
   end
 
   step 'I fill the commit message' do
-    fill_in :commit_message, with: 'Not yet a commit message.', visible: true
+    fill_in :commit_message, with: 'New commit message', visible: true
   end
 
   step 'I click link "Diff"' do
@@ -103,7 +109,7 @@ class Spinach::Features::ProjectSourceBrowseFiles < Spinach::FeatureSteps
   end
 
   step 'I click on "Delete"' do
-    click_button 'Delete'
+    click_on 'Delete'
   end
 
   step 'I click on "Delete file"' do
@@ -111,7 +117,7 @@ class Spinach::Features::ProjectSourceBrowseFiles < Spinach::FeatureSteps
   end
 
   step 'I click on "Replace"' do
-    click_button  "Replace"
+    click_on  "Replace"
   end
 
   step 'I click on "Replace file"' do
@@ -124,7 +130,7 @@ class Spinach::Features::ProjectSourceBrowseFiles < Spinach::FeatureSteps
 
   step 'I click on "New file" link in repo' do
     find('.add-to-tree').click
-    click_link 'Create file'
+    click_link 'New file'
   end
 
   step 'I click on "Upload file" link in repo' do
@@ -155,7 +161,7 @@ class Spinach::Features::ProjectSourceBrowseFiles < Spinach::FeatureSteps
   end
 
   step 'I can see the new commit message' do
-    expect(page).to have_content "New upload commit message"
+    expect(page).to have_content "New commit message"
   end
 
   step 'I upload a new text file' do
@@ -164,7 +170,7 @@ class Spinach::Features::ProjectSourceBrowseFiles < Spinach::FeatureSteps
 
   step 'I fill the upload file commit message' do
     page.within('#modal-upload-blob') do
-      fill_in :commit_message, with: 'New upload commit message'
+      fill_in :commit_message, with: 'New commit message'
     end
   end
 
@@ -251,9 +257,14 @@ class Spinach::Features::ProjectSourceBrowseFiles < Spinach::FeatureSteps
     expect(current_path).to eq(new_namespace_project_merge_request_path(@project.namespace, @project))
   end
 
+  step "I am redirected to the fork's new merge request page" do
+    fork = @user.fork_of(@project)
+    expect(current_path).to eq(new_namespace_project_merge_request_path(fork.namespace, fork))
+  end
+
   step 'I am redirected to the root directory' do
     expect(current_path).to eq(
-      namespace_project_tree_path(@project.namespace, @project, 'master/'))
+      namespace_project_tree_path(@project.namespace, @project, 'master'))
   end
 
   step "I don't see the permalink link" do
@@ -332,8 +343,12 @@ class Spinach::Features::ProjectSourceBrowseFiles < Spinach::FeatureSteps
     expect(page).to have_content 'Permalink'
     expect(page).not_to have_content 'Edit'
     expect(page).not_to have_content 'Blame'
-    expect(page).not_to have_content 'Delete'
-    expect(page).not_to have_content 'Replace'
+    expect(page).to have_content 'Delete'
+    expect(page).to have_content 'Replace'
+  end
+
+  step 'I should see a notice about a new fork having been created' do
+    expect(page).to have_content "You're not allowed to make changes to this project directly. A fork of this project has been created that you can make changes in, so you can submit a merge request."
   end
 
   private
diff --git a/features/steps/project/star.rb b/features/steps/project/star.rb
index bd2e0619cddd8be94d6717fec3d268a41313cc14..9f7c748a3b78ff3bae147189db11af8c430908e2 100644
--- a/features/steps/project/star.rb
+++ b/features/steps/project/star.rb
@@ -32,6 +32,6 @@ class Spinach::Features::ProjectStar < Spinach::FeatureSteps
   protected
 
   def has_n_stars(n)
-    expect(page).to have_css(".star-btn .count", text: n, visible: true)
+    expect(page).to have_css(".star-count", text: n, visible: true)
   end
 end
diff --git a/fixtures/emojis/aliases.json b/fixtures/emojis/aliases.json
new file mode 100644
index 0000000000000000000000000000000000000000..547ce7978b389ca4a5273cdbdbbcabb9bb42d275
--- /dev/null
+++ b/fixtures/emojis/aliases.json
@@ -0,0 +1,367 @@
+{  
+   "northeast_pointing_airplane":"airplane_northeast",
+   "small_airplane":"airplane_small",
+   "up_pointing_small_airplane":"airplane_small_up",
+   "up_pointing_airplane":"airplane_up",
+   "left_anger_bubble":"anger_left",
+   "right_anger_bubble":"anger_right",
+   "ballot_box_with_ballot":"ballot_box",
+   "ballot_box_with_bold_check":"ballot_box_check",
+   "ballot_box_with_script_x":"ballot_box_x",
+   "ballot_script_x":"ballot_x",
+   "beach_with_umbrella":"beach",
+   "bellhop_bell":"bellhop",
+   "bouquet_of_flowers":"bouquet2",
+   "bullhorn_with_sound_waves":"bullhorn_waves",
+   "pocket calculator":"calculator",
+   "spiral_calendar_pad":"calendar_spiral",
+   "card_file_box":"card_box",
+   "tape_cartridge":"cartridge",
+   "city_sunrise":"city_sunset",
+   "mantlepiece_clock":"clock",
+   "clockwise_right_and_left_semicircle_arrows":"clockwise_arrows",
+   "cloud_with_lightning":"cloud_lightning",
+   "cloud_with_rain":"cloud_rain",
+   "cloud_with_snow":"cloud_snow",
+   "cloud_with_tornado":"cloud_tornado",
+   "old_personal_computer":"computer_old",
+   "building_construction":"contruction_site",
+   "couch_and_lamp":"couch",
+   "couple_with_heart_mm":"couple_mm",
+   "couple_with_heart_ww":"couple_ww",
+   "lower_left_crayon":"crayon",
+   "heavy_latin_cross":"cross_heavy",
+   "white_latin_cross":"cross_white",
+   "black_skull_and_crossbones":"crossbones",
+   "passenger_ship":"cruise_ship",
+   "dagger_knife":"dagger",
+   "desktop_computer":"desktop",
+   "card_index_dividers":"dividers",
+   "document_with_text":"document_text",
+   "dove_of_peace":"dove",
+   "email":"e-mail",
+   "back_of_envelope":"envelope_back",
+   "flying_envelope":"envelope_flying",
+   "stamped_envelope":"envelope_stamped",
+   "pen_over_stamped_envelope":"envelope_stamped_pen",
+   "white_down_pointing_left_hand_index":"finger_pointing_down",
+   "sideways_white_down_pointing_index":"finger_pointing_down2",
+   "sideways_white_left_pointing_index":"finger_pointing_left",
+   "sideways_white_right_pointing_index":"finger_pointing_right",
+   "sideways_white_up_pointing_index":"finger_pointing_up",
+   "flame":"fire",
+   "oncoming_fire_engine":"fire_engine_oncoming",
+   "ac":"flag_ac",
+   "ad":"flag_ad",
+   "ae":"flag_ae",
+   "af":"flag_af",
+   "ag":"flag_ag",
+   "ai":"flag_ai",
+   "al":"flag_al",
+   "am":"flag_am",
+   "ao":"flag_ao",
+   "ar":"flag_ar",
+   "at":"flag_at",
+   "au":"flag_au",
+   "aw":"flag_aw",
+   "az":"flag_az",
+   "ba":"flag_ba",
+   "bb":"flag_bb",
+   "bd":"flag_bd",
+   "be":"flag_be",
+   "bf":"flag_bf",
+   "bg":"flag_bg",
+   "bh":"flag_bh",
+   "bi":"flag_bi",
+   "bj":"flag_bj",
+   "waving_black_flag":"flag_black",
+   "bm":"flag_bm",
+   "bn":"flag_bn",
+   "bo":"flag_bo",
+   "br":"flag_br",
+   "bs":"flag_bs",
+   "bt":"flag_bt",
+   "bw":"flag_bw",
+   "by":"flag_by",
+   "bz":"flag_bz",
+   "ca":"flag_ca",
+   "congo":"flag_cd",
+   "cf":"flag_cf",
+   "cg":"flag_cg",
+   "ch":"flag_ch",
+   "ci":"flag_ci",
+   "chile":"flag_cl",
+   "cm":"flag_cm",
+   "cn":"flag_cn",
+   "co":"flag_co",
+   "cr":"flag_cr",
+   "cu":"flag_cu",
+   "cv":"flag_cv",
+   "cy":"flag_cy",
+   "cz":"flag_cz",
+   "de":"flag_de",
+   "dj":"flag_dj",
+   "dk":"flag_dk",
+   "dm":"flag_dm",
+   "do":"flag_do",
+   "dz":"flag_dz",
+   "ec":"flag_ec",
+   "ee":"flag_ee",
+   "eg":"flag_eg",
+   "eh":"flag_eh",
+   "er":"flag_er",
+   "es":"flag_es",
+   "et":"flag_et",
+   "fi":"flag_fi",
+   "fj":"flag_fj",
+   "fk":"flag_fk",
+   "fm":"flag_fm",
+   "fo":"flag_fo",
+   "fr":"flag_fr",
+   "ga":"flag_ga",
+   "gb":"flag_gb",
+   "gd":"flag_gd",
+   "ge":"flag_ge",
+   "gh":"flag_gh",
+   "gi":"flag_gi",
+   "gl":"flag_gl",
+   "gm":"flag_gm",
+   "gn":"flag_gn",
+   "gq":"flag_gq",
+   "gr":"flag_gr",
+   "gt":"flag_gt",
+   "gu":"flag_gu",
+   "gw":"flag_gw",
+   "gy":"flag_gy",
+   "hk":"flag_hk",
+   "hn":"flag_hn",
+   "hr":"flag_hr",
+   "ht":"flag_ht",
+   "hu":"flag_hu",
+   "indonesia":"flag_id",
+   "ie":"flag_ie",
+   "il":"flag_il",
+   "in":"flag_in",
+   "iq":"flag_iq",
+   "ir":"flag_ir",
+   "is":"flag_is",
+   "it":"flag_it",
+   "je":"flag_je",
+   "jm":"flag_jm",
+   "jo":"flag_jo",
+   "jp":"flag_jp",
+   "ke":"flag_ke",
+   "kg":"flag_kg",
+   "kh":"flag_kh",
+   "ki":"flag_ki",
+   "km":"flag_km",
+   "kn":"flag_kn",
+   "kp":"flag_kp",
+   "kr":"flag_kr",
+   "kw":"flag_kw",
+   "ky":"flag_ky",
+   "kz":"flag_kz",
+   "la":"flag_la",
+   "lb":"flag_lb",
+   "lc":"flag_lc",
+   "li":"flag_li",
+   "lk":"flag_lk",
+   "lr":"flag_lr",
+   "ls":"flag_ls",
+   "lt":"flag_lt",
+   "lu":"flag_lu",
+   "lv":"flag_lv",
+   "ly":"flag_ly",
+   "ma":"flag_ma",
+   "mc":"flag_mc",
+   "md":"flag_md",
+   "me":"flag_me",
+   "mg":"flag_mg",
+   "mh":"flag_mh",
+   "mk":"flag_mk",
+   "ml":"flag_ml",
+   "mm":"flag_mm",
+   "mn":"flag_mn",
+   "mo":"flag_mo",
+   "mr":"flag_mr",
+   "ms":"flag_ms",
+   "mt":"flag_mt",
+   "mu":"flag_mu",
+   "mv":"flag_mv",
+   "mw":"flag_mw",
+   "mx":"flag_mx",
+   "my":"flag_my",
+   "mz":"flag_mz",
+   "na":"flag_na",
+   "nc":"flag_nc",
+   "ne":"flag_ne",
+   "nigeria":"flag_ng",
+   "ni":"flag_ni",
+   "nl":"flag_nl",
+   "no":"flag_no",
+   "np":"flag_np",
+   "nr":"flag_nr",
+   "nu":"flag_nu",
+   "nz":"flag_nz",
+   "om":"flag_om",
+   "pa":"flag_pa",
+   "pe":"flag_pe",
+   "pf":"flag_pf",
+   "pg":"flag_pg",
+   "ph":"flag_ph",
+   "pk":"flag_pk",
+   "pl":"flag_pl",
+   "pr":"flag_pr",
+   "ps":"flag_ps",
+   "pt":"flag_pt",
+   "pw":"flag_pw",
+   "py":"flag_py",
+   "qa":"flag_qa",
+   "ro":"flag_ro",
+   "rs":"flag_rs",
+   "ru":"flag_ru",
+   "rw":"flag_rw",
+   "saudiarabia":"flag_sa",
+   "saudi":"flag_sa",
+   "sb":"flag_sb",
+   "sc":"flag_sc",
+   "sd":"flag_sd",
+   "se":"flag_se",
+   "sg":"flag_sg",
+   "sh":"flag_sh",
+   "si":"flag_si",
+   "sk":"flag_sk",
+   "sl":"flag_sl",
+   "sm":"flag_sm",
+   "sn":"flag_sn",
+   "so":"flag_so",
+   "sr":"flag_sr",
+   "st":"flag_st",
+   "sv":"flag_sv",
+   "sy":"flag_sy",
+   "sz":"flag_sz",
+   "td":"flag_td",
+   "tg":"flag_tg",
+   "th":"flag_th",
+   "tj":"flag_tj",
+   "tl":"flag_tl",
+   "turkmenistan":"flag_tm",
+   "tn":"flag_tn",
+   "to":"flag_to",
+   "tr":"flag_tr",
+   "tt":"flag_tt",
+   "tuvalu":"flag_tv",
+   "tw":"flag_tw",
+   "tz":"flag_tz",
+   "ua":"flag_ua",
+   "ug":"flag_ug",
+   "us":"flag_us",
+   "uy":"flag_uy",
+   "uz":"flag_uz",
+   "va":"flag_va",
+   "vc":"flag_vc",
+   "ve":"flag_ve",
+   "vi":"flag_vi",
+   "vn":"flag_vn",
+   "vu":"flag_vu",
+   "wf":"flag_wf",
+   "waving_white_flag":"flag_white",
+   "ws":"flag_ws",
+   "xk":"flag_xk",
+   "ye":"flag_ye",
+   "za":"flag_za",
+   "zm":"flag_zm",
+   "zw":"flag_zw",
+   "clamshell_mobile_phone":"flip_phone",
+   "black_hard_shell_floppy_disk":"floppy_black",
+   "white_hard_shell_floppy_disk":"floppy_white",
+   "open_folder":"folder_open",
+   "fork_and_knife_with_plate":"fork_knife_plate",
+   "frame_with_picture":"frame_photo",
+   "frame_with_tiles":"frame_tiles",
+   "frame_with_an_x":"frame_x",
+   "anguished":"frowning",
+   "raised_hand_with_fingers_splayed":"hand_splayed",
+   "reversed_raised_hand_with_fingers_splayed":"hand_splayed_reverse",
+   "reversed_victory_hand":"hand_victory",
+   "heart_with_tip_on_the_left":"heart_tip",
+   "house_buildings":"homes",
+   "derelict_house_building":"house_abandoned",
+   "circled_information_source":"info",
+   "desert_island":"island",
+   "up_pointing_military_airplane":"jet_up",
+   "old_key":"key2",
+   "wired_keyboard":"keyboard",
+   "keyboard_and_mouse":"keyboard_mouse",
+   "musical_keyboard_with_jacks":"keyboard_with_jacks",
+   "couplekiss_mm":"kiss_mm",
+   "couplekiss_ww":"kiss_ww",
+   "satisfied":"laughing",
+   "left_hand_telephone_receiver":"left_receiver",
+   "man_in_business_suit_levitating":"levitate",
+   "weight_lifter":"lifter",
+   "light_mark":"light_check_mark",
+   "world_map":"map",
+   "sports_medal":"medal",
+   "studio_microphone":"microphone2",
+   "reversed_hand_with_middle_finger_extended":"middle_finger",
+   "lightning_mood_bubble":"mood_bubble_lightning",
+   "lightning_mood":"mood_lightning",
+   "racing_motorcycle":"motorcycle",
+   "snow_capped_mountain":"mountain_snow",
+   "one_button_mouse":"mouse_one",
+   "three_networked_computers":"network",
+   "rolled_up_newspaper":"newspaper2",
+   "note_page":"note",
+   "empty_note_page":"note_empty",
+   "note_pad":"notepad",
+   "empty_note_pad":"notepad_empty",
+   "spiral_note_pad":"notepad_spiral",
+   "oil_drum":"oil",
+   "grandma":"older_woman",
+   "optical_disc_icon":"optical_disk",
+   "lower_left_paintbrush":"paintbrush",
+   "linked_paperclips":"paperclips",
+   "national_park":"park",
+   "lower_left_ballpoint_pen":"pen_ballpoint",
+   "lower_left_fountain_pen":"pen_fountain",
+   "memo":"pencil",
+   "lower_left_pencil":"pencil3",
+   "black_pennant":"pennant_black",
+   "white_pennant":"pennant_white",
+   "no_piracy":"piracy",
+   "shit":"poop",
+   "hankey":"poop",
+   "poo":"poop",
+   "prohibited_sign":"prohibited",
+   "film_projector":"projector",
+   "racing_car":"race_car",
+   "railroad_track":"railway_track",
+   "right_speaker_with_one_sound_wave":"right_speaker_one",
+   "right_speaker_with_three_sound_waves":"right_speaker_three",
+   "skeleton":"skull",
+   "slightly_frowning_face":"slight_frown",
+   "slightly_smiling_face":"slight_smile",
+   "speaking_head_in_silhouette":"speaking_head",
+   "left_speech_bubble":"speech_left",
+   "right_speech_bubble":"speech_right",
+   "three_speech_bubbles":"speech_three",
+   "two_speech_bubbles":"speech_two",
+   "sleuth_or_spy":"spy",
+   "portable_stereo":"stereo",
+   "black_touchtone_telephone":"telephone_black",
+   "white_touchtone_telephone":"telephone_white",
+   "left_thought_bubble":"thought_left",
+   "right_thought_bubble":"thought_right",
+   "reversed_thumbs_down_sign":"thumbs_down_reverse",
+   "reversed_thumbs_up_sign":"thumbs_up_reverse",
+   "-1":"thumbsdown",
+   "+1":"thumbsup",
+   "admission_tickets":"tickets",
+   "hammer_and_wrench":"tools",
+   "diesel_locomotive":"train_diesel",
+   "triangle_with_rounded_corners":"triangle_round",
+   "turned_ok_hand_sign":"turned_ok_hand",
+   "raised_hand_with_part_between_middle_and_ring_fingers":"vulcan",
+   "left_writing_hand":"writing_hand"
+}
\ No newline at end of file
diff --git a/fixtures/emojis/index.json b/fixtures/emojis/index.json
new file mode 100644
index 0000000000000000000000000000000000000000..60ef2399e14de6b711aa4a5e0b92ce97ab1e791a
--- /dev/null
+++ b/fixtures/emojis/index.json
@@ -0,0 +1,13376 @@
+{
+  "100": {
+    "unicode": "1F4AF",
+    "unicode_alternates": [],
+    "name": "hundred points symbol",
+    "shortname": ":100:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["numbers", "perfect", "score", "100", "percent", "a", "plus", "perfect", "school", "quiz", "score", "test", "exam"],
+    "moji": "💯"
+  },
+  "1234": {
+    "unicode": "1F522",
+    "unicode_alternates": [],
+    "name": "input symbol for numbers",
+    "shortname": ":1234:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blue-square", "numbers"],
+    "moji": "🔢"
+  },
+  "8ball": {
+    "unicode": "1F3B1",
+    "unicode_alternates": [],
+    "name": "billiards",
+    "shortname": ":8ball:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["pool", "billiards", "eight ball", "pool", "pocket ball", "cue"],
+    "moji": "🎱"
+  },
+  "a": {
+    "unicode": "1F170",
+    "unicode_alternates": [],
+    "name": "negative squared latin capital letter a",
+    "shortname": ":a:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["alphabet", "letter", "red-square"],
+    "moji": "🅰"
+  },
+  "ab": {
+    "unicode": "1F18E",
+    "unicode_alternates": [],
+    "name": "negative squared ab",
+    "shortname": ":ab:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["alphabet", "red-square"],
+    "moji": "🆎"
+  },
+  "abc": {
+    "unicode": "1F524",
+    "unicode_alternates": [],
+    "name": "input symbol for latin letters",
+    "shortname": ":abc:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["alphabet", "blue-square"],
+    "moji": "🔤"
+  },
+  "abcd": {
+    "unicode": "1F521",
+    "unicode_alternates": [],
+    "name": "input symbol for latin small letters",
+    "shortname": ":abcd:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["alphabet", "blue-square"],
+    "moji": "🔡"
+  },
+  "accept": {
+    "unicode": "1F251",
+    "unicode_alternates": [],
+    "name": "circled ideograph accept",
+    "shortname": ":accept:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["agree", "chinese", "good", "kanji", "ok", "yes"],
+    "moji": "🉑"
+  },
+  "aerial_tramway": {
+    "unicode": "1F6A1",
+    "unicode_alternates": [],
+    "name": "aerial tramway",
+    "shortname": ":aerial_tramway:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["transportation", "vehicle", "aerial", "tram", "tramway", "cable", "transport"],
+    "moji": "🚡"
+  },
+  "airplane": {
+    "unicode": "2708",
+    "unicode_alternates": ["2708-FE0F"],
+    "name": "airplane",
+    "shortname": ":airplane:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["flight", "transportation", "vehicle", "airplane", "plane", "airport", "travel", "airlines", "fly", "jet", "jumbo", "boeing", "airbus"],
+    "moji": "✈"
+  },
+  "airplane_arriving": {
+    "unicode": "1F6EC",
+    "unicode_alternates": [],
+    "name": "airplane arriving",
+    "shortname": ":airplane_arriving:",
+    "category": "travel_places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["flight", "transportation", "vehicle", "plane", "airport", "travel", "airlines", "fly", "jet", "jumbo", "boeing", "airbus"]
+  },
+  "airplane_departure": {
+    "unicode": "1F6EB",
+    "unicode_alternates": [],
+    "name": "airplane departure",
+    "shortname": ":airplane_departure:",
+    "category": "travel_places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["flight", "transportation", "vehicle", "plane", "airport", "travel", "airlines", "fly", "jet", "jumbo", "boeing", "airbus", "leaving"]
+  },
+  "airplane_northeast": {
+    "unicode": "1F6EA",
+    "unicode_alternates": [],
+    "name": "northeast-pointing airplane",
+    "shortname": ":airplane_northeast:",
+    "category": "travel_places",
+    "aliases": [":northeast_pointing_airplane:"],
+    "aliases_ascii": [],
+    "keywords": ["plane", "travel"]
+  },
+  "airplane_small": {
+    "unicode": "1F6E9",
+    "unicode_alternates": [],
+    "name": "small airplane",
+    "shortname": ":airplane_small:",
+    "category": "travel_places",
+    "aliases": [":small_airplane:"],
+    "aliases_ascii": [],
+    "keywords": ["flight", "transportation", "vehicle", "plane", "airport", "travel", "airlines", "fly", "jet", "jumbo", "boeing", "airbus"]
+  },
+  "airplane_small_up": {
+    "unicode": "1F6E8",
+    "unicode_alternates": [],
+    "name": "up-pointing small airplane",
+    "shortname": ":airplane_small_up:",
+    "category": "travel_places",
+    "aliases": [":up_pointing_small_airplane:"],
+    "aliases_ascii": [],
+    "keywords": ["plane", "travel"]
+  },
+  "airplane_up": {
+    "unicode": "1F6E7",
+    "unicode_alternates": [],
+    "name": "up-pointing airplane",
+    "shortname": ":airplane_up:",
+    "category": "travel_places",
+    "aliases": [":up_pointing_airplane:"],
+    "aliases_ascii": [],
+    "keywords": ["plane", "travel"]
+  },
+  "alarm_clock": {
+    "unicode": "23F0",
+    "unicode_alternates": [],
+    "name": "alarm clock",
+    "shortname": ":alarm_clock:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["time", "wake"],
+    "moji": "⏰"
+  },
+  "alien": {
+    "unicode": "1F47D",
+    "unicode_alternates": [],
+    "name": "extraterrestrial alien",
+    "shortname": ":alien:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["UFO", "paul", "alien", "ufo"],
+    "moji": "👽"
+  },
+  "ambulance": {
+    "unicode": "1F691",
+    "unicode_alternates": [],
+    "name": "ambulance",
+    "shortname": ":ambulance:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["911", "health", "ambulance", "emergency", "medical", "help", "assistance"],
+    "moji": "🚑"
+  },
+  "anchor": {
+    "unicode": "2693",
+    "unicode_alternates": ["2693-FE0F"],
+    "name": "anchor",
+    "shortname": ":anchor:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["ferry", "ship", "anchor", "ship", "boat", "ocean", "harbor", "marina", "shipyard", "sailor", "tattoo"],
+    "moji": "âš“"
+  },
+  "angel": {
+    "unicode": "1F47C",
+    "unicode_alternates": [],
+    "name": "baby angel",
+    "shortname": ":angel:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["baby", "angel", "halo", "cupid", "wings", "halo", "heaven", "wings", "jesus"],
+    "moji": "👼"
+  },
+  "anger": {
+    "unicode": "1F4A2",
+    "unicode_alternates": [],
+    "name": "anger symbol",
+    "shortname": ":anger:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["anger", "angry", "mad"],
+    "moji": "💢"
+  },
+  "anger_left": {
+    "unicode": "1F5EE",
+    "unicode_alternates": [],
+    "name": "left anger bubble",
+    "shortname": ":anger_left:",
+    "category": "objects_symbols",
+    "aliases": [":left_anger_bubble:"],
+    "aliases_ascii": [],
+    "keywords": ["speech", "balloon", "talk", "mood", "conversation", "communication", "comic", "angry"]
+  },
+  "anger_right": {
+    "unicode": "1F5EF",
+    "unicode_alternates": [],
+    "name": "right anger bubble",
+    "shortname": ":anger_right:",
+    "category": "objects_symbols",
+    "aliases": [":right_anger_bubble:"],
+    "aliases_ascii": [],
+    "keywords": ["speech", "balloon", "talk", "mood", "conversation", "communication", "comic", "angry"]
+  },
+  "angry": {
+    "unicode": "1F620",
+    "unicode_alternates": [],
+    "name": "angry face",
+    "shortname": ":angry:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [">:(", ">:-(", ":@"],
+    "keywords": ["angry", "livid", "mad", "vexed", "irritated", "annoyed", "face", "frustrated", "mad"],
+    "moji": "😠"
+  },
+  "anguished": {
+    "unicode": "1F627",
+    "unicode_alternates": [],
+    "name": "anguished face",
+    "shortname": ":anguished:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["face", "nervous", "stunned", "pain", "anguish", "ouch", "misery", "distress", "grief"],
+    "moji": "😧"
+  },
+  "ant": {
+    "unicode": "1F41C",
+    "unicode_alternates": [],
+    "name": "ant",
+    "shortname": ":ant:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "insect", "ant", "queen", "insect", "team"],
+    "moji": "🐜"
+  },
+  "apple": {
+    "unicode": "1F34E",
+    "unicode_alternates": [],
+    "name": "red apple",
+    "shortname": ":apple:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["fruit", "mac", "apple", "fruit", "electronics", "red", "doctor", "teacher", "school", "core"],
+    "moji": "🍎"
+  },
+  "aquarius": {
+    "unicode": "2652",
+    "unicode_alternates": ["2652-FE0F"],
+    "name": "aquarius",
+    "shortname": ":aquarius:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["aquarius", "water", "bearer", "astrology", "greek", "constellation", "stars", "zodiac", "sign", "purple-square", "sign", "zodiac", "horoscope"],
+    "moji": "â™’"
+  },
+  "aries": {
+    "unicode": "2648",
+    "unicode_alternates": ["2648-FE0F"],
+    "name": "aries",
+    "shortname": ":aries:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["aries", "ram", "astrology", "greek", "constellation", "stars", "zodiac", "sign", "purple-square", "sign", "zodiac", "horoscope"],
+    "moji": "♈"
+  },
+  "arrow_backward": {
+    "unicode": "25C0",
+    "unicode_alternates": ["25C0-FE0F"],
+    "name": "black left-pointing triangle",
+    "shortname": ":arrow_backward:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["arrow", "blue-square"],
+    "moji": "â—€"
+  },
+  "arrow_double_down": {
+    "unicode": "23EC",
+    "unicode_alternates": [],
+    "name": "black down-pointing double triangle",
+    "shortname": ":arrow_double_down:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["arrow", "blue-square"],
+    "moji": "⏬"
+  },
+  "arrow_double_up": {
+    "unicode": "23EB",
+    "unicode_alternates": [],
+    "name": "black up-pointing double triangle",
+    "shortname": ":arrow_double_up:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["arrow", "blue-square"],
+    "moji": "⏫"
+  },
+  "arrow_down": {
+    "unicode": "2B07",
+    "unicode_alternates": ["2B07-FE0F"],
+    "name": "downwards black arrow",
+    "shortname": ":arrow_down:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["arrow", "blue-square"],
+    "moji": "⬇"
+  },
+  "arrow_down_small": {
+    "unicode": "1F53D",
+    "unicode_alternates": [],
+    "name": "down-pointing small red triangle",
+    "shortname": ":arrow_down_small:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["arrow", "blue-square"],
+    "moji": "🔽"
+  },
+  "arrow_forward": {
+    "unicode": "25B6",
+    "unicode_alternates": ["25B6-FE0F"],
+    "name": "black right-pointing triangle",
+    "shortname": ":arrow_forward:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["arrow", "blue-square"],
+    "moji": "â–¶"
+  },
+  "arrow_heading_down": {
+    "unicode": "2935",
+    "unicode_alternates": ["2935-FE0F"],
+    "name": "arrow pointing rightwards then curving downwards",
+    "shortname": ":arrow_heading_down:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["arrow", "blue-square"],
+    "moji": "⤵"
+  },
+  "arrow_heading_up": {
+    "unicode": "2934",
+    "unicode_alternates": ["2934-FE0F"],
+    "name": "arrow pointing rightwards then curving upwards",
+    "shortname": ":arrow_heading_up:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["arrow", "blue-square"],
+    "moji": "⤴"
+  },
+  "arrow_left": {
+    "unicode": "2B05",
+    "unicode_alternates": ["2B05-FE0F"],
+    "name": "leftwards black arrow",
+    "shortname": ":arrow_left:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["arrow", "blue-square", "previous"],
+    "moji": "⬅"
+  },
+  "arrow_lower_left": {
+    "unicode": "2199",
+    "unicode_alternates": ["2199-FE0F"],
+    "name": "south west arrow",
+    "shortname": ":arrow_lower_left:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["arrow", "blue-square"],
+    "moji": "↙"
+  },
+  "arrow_lower_right": {
+    "unicode": "2198",
+    "unicode_alternates": ["2198-FE0F"],
+    "name": "south east arrow",
+    "shortname": ":arrow_lower_right:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["arrow", "blue-square"],
+    "moji": "↘"
+  },
+  "arrow_right": {
+    "unicode": "27A1",
+    "unicode_alternates": ["27A1-FE0F"],
+    "name": "black rightwards arrow",
+    "shortname": ":arrow_right:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blue-square", "next"],
+    "moji": "âž¡"
+  },
+  "arrow_right_hook": {
+    "unicode": "21AA",
+    "unicode_alternates": ["21AA-FE0F"],
+    "name": "rightwards arrow with hook",
+    "shortname": ":arrow_right_hook:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blue-square"],
+    "moji": "↪"
+  },
+  "arrow_up": {
+    "unicode": "2B06",
+    "unicode_alternates": ["2B06-FE0F"],
+    "name": "upwards black arrow",
+    "shortname": ":arrow_up:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blue-square"],
+    "moji": "⬆"
+  },
+  "arrow_up_down": {
+    "unicode": "2195",
+    "unicode_alternates": ["2195-FE0F"],
+    "name": "up down arrow",
+    "shortname": ":arrow_up_down:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blue-square"],
+    "moji": "↕"
+  },
+  "arrow_up_small": {
+    "unicode": "1F53C",
+    "unicode_alternates": [],
+    "name": "up-pointing small red triangle",
+    "shortname": ":arrow_up_small:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blue-square"],
+    "moji": "🔼"
+  },
+  "arrow_upper_left": {
+    "unicode": "2196",
+    "unicode_alternates": ["2196-FE0F"],
+    "name": "north west arrow",
+    "shortname": ":arrow_upper_left:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blue-square"],
+    "moji": "↖"
+  },
+  "arrow_upper_right": {
+    "unicode": "2197",
+    "unicode_alternates": ["2197-FE0F"],
+    "name": "north east arrow",
+    "shortname": ":arrow_upper_right:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blue-square"],
+    "moji": "↗"
+  },
+  "arrows_clockwise": {
+    "unicode": "1F503",
+    "unicode_alternates": [],
+    "name": "clockwise downwards and upwards open circle arrows",
+    "shortname": ":arrows_clockwise:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["sync"],
+    "moji": "🔃"
+  },
+  "arrows_counterclockwise": {
+    "unicode": "1F504",
+    "unicode_alternates": [],
+    "name": "anticlockwise downwards and upwards open circle ar",
+    "shortname": ":arrows_counterclockwise:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blue-square", "sync"],
+    "moji": "🔄"
+  },
+  "art": {
+    "unicode": "1F3A8",
+    "unicode_alternates": [],
+    "name": "artist palette",
+    "shortname": ":art:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["design", "draw", "paint", "artist", "palette", "art", "colors", "paint", "draw", "brush", "pastels", "oils"],
+    "moji": "🎨"
+  },
+  "articulated_lorry": {
+    "unicode": "1F69B",
+    "unicode_alternates": [],
+    "name": "articulated lorry",
+    "shortname": ":articulated_lorry:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["cars", "transportation", "vehicle", "truck", "delivery", "semi", "lorry", "articulated"],
+    "moji": "🚛"
+  },
+  "ascending_notes": {
+    "unicode": "1F39C",
+    "unicode_alternates": [],
+    "name": "beamed ascending musical notes",
+    "shortname": ":ascending_notes:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["score", "music", "sound", "tone"]
+  },
+  "astonished": {
+    "unicode": "1F632",
+    "unicode_alternates": [],
+    "name": "astonished face",
+    "shortname": ":astonished:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["face", "xox", "shocked", "surprise", "astonished"],
+    "moji": "😲"
+  },
+  "athletic_shoe": {
+    "unicode": "1F45F",
+    "unicode_alternates": [],
+    "name": "athletic shoe",
+    "shortname": ":athletic_shoe:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["shoes", "sports"],
+    "moji": "👟"
+  },
+  "atm": {
+    "unicode": "1F3E7",
+    "unicode_alternates": [],
+    "name": "automated teller machine",
+    "shortname": ":atm:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["atm", "cash", "withdrawal", "money", "deposit", "financial", "bank", "adam", "payday", "bank", "blue-square", "cash", "money", "payment"],
+    "moji": "🏧"
+  },
+  "b": {
+    "unicode": "1F171",
+    "unicode_alternates": [],
+    "name": "negative squared latin capital letter b",
+    "shortname": ":b:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["alphabet", "letter", "red-square"],
+    "moji": "🅱"
+  },
+  "baby": {
+    "unicode": "1F476",
+    "unicode_alternates": [],
+    "name": "baby",
+    "shortname": ":baby:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["boy", "child", "infant"],
+    "moji": "👶"
+  },
+  "baby_bottle": {
+    "unicode": "1F37C",
+    "unicode_alternates": [],
+    "name": "baby bottle",
+    "shortname": ":baby_bottle:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["container", "food", "baby", "bottle", "milk", "mother", "nipple", "newborn", "formula"],
+    "moji": "🍼"
+  },
+  "baby_chick": {
+    "unicode": "1F424",
+    "unicode_alternates": [],
+    "name": "baby chick",
+    "shortname": ":baby_chick:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "chicken", "chick", "baby", "bird", "chicken", "young", "woman", "cute"],
+    "moji": "🐤"
+  },
+  "baby_symbol": {
+    "unicode": "1F6BC",
+    "unicode_alternates": [],
+    "name": "baby symbol",
+    "shortname": ":baby_symbol:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["child", "orange-square", "baby", "crawl", "newborn", "human", "diaper", "small", "babe"],
+    "moji": "🚼"
+  },
+  "back": {
+    "unicode": "1F519",
+    "unicode_alternates": [],
+    "name": "back with leftwards arrow above",
+    "shortname": ":back:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["arrow"],
+    "moji": "🔙"
+  },
+  "baggage_claim": {
+    "unicode": "1F6C4",
+    "unicode_alternates": [],
+    "name": "baggage claim",
+    "shortname": ":baggage_claim:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["airport", "blue-square", "transport", "bag", "baggage", "luggage", "travel"],
+    "moji": "🛄"
+  },
+  "balloon": {
+    "unicode": "1F388",
+    "unicode_alternates": [],
+    "name": "balloon",
+    "shortname": ":balloon:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["celebration", "party", "balloon", "birthday", "celebration", "helium", "gas", "children", "float"],
+    "moji": "🎈"
+  },
+  "ballot_box": {
+    "unicode": "1F5F3",
+    "unicode_alternates": [],
+    "name": "ballot box with ballot",
+    "shortname": ":ballot_box:",
+    "category": "objects_symbols",
+    "aliases": [":ballot_box_with_ballot:"],
+    "aliases_ascii": [],
+    "keywords": ["vote"]
+  },
+  "ballot_box_check": {
+    "unicode": "1F5F9",
+    "unicode_alternates": [],
+    "name": "ballot box with bold check",
+    "shortname": ":ballot_box_check:",
+    "category": "objects_symbols",
+    "aliases": [":ballot_box_with_bold_check:"],
+    "aliases_ascii": [],
+    "keywords": ["mark", "vote"]
+  },
+  "ballot_box_with_check": {
+    "unicode": "2611",
+    "unicode_alternates": ["2611-FE0F"],
+    "name": "ballot box with check",
+    "shortname": ":ballot_box_with_check:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["agree", "ok"],
+    "moji": "☑"
+  },
+  "ballot_box_x": {
+    "unicode": "1F5F5",
+    "unicode_alternates": [],
+    "name": "ballot box with script x",
+    "shortname": ":ballot_box_x:",
+    "category": "objects_symbols",
+    "aliases": [":ballot_box_with_script_x:"],
+    "aliases_ascii": [],
+    "keywords": ["mark", "vote"]
+  },
+  "ballot_x": {
+    "unicode": "1F5F4",
+    "unicode_alternates": [],
+    "name": "ballot script x",
+    "shortname": ":ballot_x:",
+    "category": "objects_symbols",
+    "aliases": [":ballot_script_x:"],
+    "aliases_ascii": [],
+    "keywords": ["mark", "vote"]
+  },
+  "bamboo": {
+    "unicode": "1F38D",
+    "unicode_alternates": [],
+    "name": "pine decoration",
+    "shortname": ":bamboo:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["nature", "plant", "vegetable", "pine", "bamboo", "decoration", "new", "years", "spirits", "harvest", "prosperity", "longevity", "fortune", "luck", "welcome", "farming", "agriculture"],
+    "moji": "🎍"
+  },
+  "banana": {
+    "unicode": "1F34C",
+    "unicode_alternates": [],
+    "name": "banana",
+    "shortname": ":banana:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["food", "fruit", "banana", "peel", "bunch"],
+    "moji": "🍌"
+  },
+  "bangbang": {
+    "unicode": "203C",
+    "unicode_alternates": ["203C-FE0F"],
+    "name": "double exclamation mark",
+    "shortname": ":bangbang:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["exclamation", "surprise"],
+    "moji": "‼"
+  },
+  "bank": {
+    "unicode": "1F3E6",
+    "unicode_alternates": [],
+    "name": "bank",
+    "shortname": ":bank:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["building"],
+    "moji": "🏦"
+  },
+  "bar_chart": {
+    "unicode": "1F4CA",
+    "unicode_alternates": [],
+    "name": "bar chart",
+    "shortname": ":bar_chart:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["graph", "presentation", "stats"],
+    "moji": "📊"
+  },
+  "barber": {
+    "unicode": "1F488",
+    "unicode_alternates": [],
+    "name": "barber pole",
+    "shortname": ":barber:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["hair", "salon", "style"],
+    "moji": "💈"
+  },
+  "baseball": {
+    "unicode": "26BE",
+    "unicode_alternates": ["26BE-FE0F"],
+    "name": "baseball",
+    "shortname": ":baseball:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["MLB", "balls", "sports"],
+    "moji": "âš¾"
+  },
+  "basketball": {
+    "unicode": "1F3C0",
+    "unicode_alternates": [],
+    "name": "basketball and hoop",
+    "shortname": ":basketball:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["NBA", "balls", "sports", "basketball", "bball", "dribble", "hoop", "net", "swish", "rip city"],
+    "moji": "🏀"
+  },
+  "bath": {
+    "unicode": "1F6C0",
+    "unicode_alternates": [],
+    "name": "bath",
+    "shortname": ":bath:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["clean", "shower", "bath", "tub", "basin", "wash", "bubble", "soak", "bathroom", "soap", "water", "clean", "shampoo", "lather", "water"],
+    "moji": "🛀"
+  },
+  "bathtub": {
+    "unicode": "1F6C1",
+    "unicode_alternates": [],
+    "name": "bathtub",
+    "shortname": ":bathtub:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["clean", "shower", "bath", "tub", "basin", "wash", "bubble", "soak", "bathroom", "soap", "water", "clean", "shampoo", "lather", "water"],
+    "moji": "🛁"
+  },
+  "battery": {
+    "unicode": "1F50B",
+    "unicode_alternates": [],
+    "name": "battery",
+    "shortname": ":battery:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["energy", "power", "sustain"],
+    "moji": "🔋"
+  },
+  "beach": {
+    "unicode": "1F3D6",
+    "unicode_alternates": [],
+    "name": "beach with umbrella",
+    "shortname": ":beach:",
+    "category": "travel_places",
+    "aliases": [":beach_with_umbrella:"],
+    "aliases_ascii": [],
+    "keywords": ["sand", "sun", "surf", "vacation", "relaxation", "tanning", "tan", "swimming"]
+  },
+  "bear": {
+    "unicode": "1F43B",
+    "unicode_alternates": [],
+    "name": "bear face",
+    "shortname": ":bear:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "nature"],
+    "moji": "🐻"
+  },
+  "bed": {
+    "unicode": "1F6CF",
+    "unicode_alternates": [],
+    "name": "bed",
+    "shortname": ":bed:",
+    "category": "travel_places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["sleep", "sex", "queen", "full", "twin", "king", "mattress"]
+  },
+  "bee": {
+    "unicode": "1F41D",
+    "unicode_alternates": [],
+    "name": "honeybee",
+    "shortname": ":bee:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "insect", "bee", "queen", "buzz", "flower", "pollen", "sting", "honey", "hive", "bumble", "pollination"],
+    "moji": "🐝"
+  },
+  "beer": {
+    "unicode": "1F37A",
+    "unicode_alternates": [],
+    "name": "beer mug",
+    "shortname": ":beer:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["beverage", "drink", "drunk", "party", "pub", "relax", "beer", "hops", "mug", "barley", "malt", "yeast", "portland", "oregon", "brewery", "micro", "pint", "boot"],
+    "moji": "🍺"
+  },
+  "beers": {
+    "unicode": "1F37B",
+    "unicode_alternates": [],
+    "name": "clinking beer mugs",
+    "shortname": ":beers:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["beverage", "drink", "drunk", "party", "pub", "relax", "beer", "beers", "cheers", "mug", "toast", "celebrate", "pub", "bar", "jolly", "hops", "clink"],
+    "moji": "🍻"
+  },
+  "beetle": {
+    "unicode": "1F41E",
+    "unicode_alternates": [],
+    "name": "lady beetle",
+    "shortname": ":beetle:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["insect", "nature", "lady", "bug", "ladybug", "ladybird", "beetle", "cow", "lady cow", "insect", "endearment"],
+    "moji": "🐞"
+  },
+  "beginner": {
+    "unicode": "1F530",
+    "unicode_alternates": [],
+    "name": "japanese symbol for beginner",
+    "shortname": ":beginner:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["badge", "shield"],
+    "moji": "🔰"
+  },
+  "bell": {
+    "unicode": "1F514",
+    "unicode_alternates": [],
+    "name": "bell",
+    "shortname": ":bell:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["chime", "christmas", "notification", "sound", "xmas"],
+    "moji": "🔔"
+  },
+  "bellhop": {
+    "unicode": "1F6CE",
+    "unicode_alternates": [],
+    "name": "bellhop bell",
+    "shortname": ":bellhop:",
+    "category": "travel_places",
+    "aliases": [":bellhop_bell:"],
+    "aliases_ascii": [],
+    "keywords": ["hotel", "porter", "ding"]
+  },
+  "bento": {
+    "unicode": "1F371",
+    "unicode_alternates": [],
+    "name": "bento box",
+    "shortname": ":bento:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["box", "food", "japanese", "bento", "japanese", "rice", "meal", "box", "obento", "convenient", "lunchbox"],
+    "moji": "🍱"
+  },
+  "bicyclist": {
+    "unicode": "1F6B4",
+    "unicode_alternates": [],
+    "name": "bicyclist",
+    "shortname": ":bicyclist:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["bike", "exercise", "hipster", "sports", "bicyclist", "road", "bike", "pedal", "bicycle", "transportation"],
+    "moji": "🚴"
+  },
+  "bike": {
+    "unicode": "1F6B2",
+    "unicode_alternates": [],
+    "name": "bicycle",
+    "shortname": ":bike:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["bicycle", "exercise", "hipster", "sports", "bike", "pedal", "bicycle", "transportation"],
+    "moji": "🚲"
+  },
+  "bikini": {
+    "unicode": "1F459",
+    "unicode_alternates": [],
+    "name": "bikini",
+    "shortname": ":bikini:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["beach", "fashion", "female", "girl", "swimming", "woman"],
+    "moji": "👙"
+  },
+  "bird": {
+    "unicode": "1F426",
+    "unicode_alternates": [],
+    "name": "bird",
+    "shortname": ":bird:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "fly", "nature", "tweet"],
+    "moji": "🐦"
+  },
+  "birthday": {
+    "unicode": "1F382",
+    "unicode_alternates": [],
+    "name": "birthday cake",
+    "shortname": ":birthday:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["cake", "party", "birthday", "birth", "cake", "dessert", "wish", "celebrate"],
+    "moji": "🎂"
+  },
+  "black_circle": {
+    "unicode": "26AB",
+    "unicode_alternates": ["26AB-FE0F"],
+    "name": "medium black circle",
+    "shortname": ":black_circle:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["shape"],
+    "moji": "âš«"
+  },
+  "black_joker": {
+    "unicode": "1F0CF",
+    "unicode_alternates": [],
+    "name": "playing card black joker",
+    "shortname": ":black_joker:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["cards", "game", "poker"],
+    "moji": "🃏"
+  },
+  "black_large_square": {
+    "unicode": "2B1B",
+    "unicode_alternates": ["2B1B-FE0F"],
+    "name": "black large square",
+    "shortname": ":black_large_square:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["shape"],
+    "moji": "⬛"
+  },
+  "black_medium_small_square": {
+    "unicode": "25FE",
+    "unicode_alternates": ["25FE-FE0F"],
+    "name": "black medium small square",
+    "shortname": ":black_medium_small_square:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": [],
+    "moji": "â—¾"
+  },
+  "black_medium_square": {
+    "unicode": "25FC",
+    "unicode_alternates": ["25FC-FE0F"],
+    "name": "black medium square",
+    "shortname": ":black_medium_square:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["shape"],
+    "moji": "â—¼"
+  },
+  "black_nib": {
+    "unicode": "2712",
+    "unicode_alternates": ["2712-FE0F"],
+    "name": "black nib",
+    "shortname": ":black_nib:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["pen", "stationery"],
+    "moji": "✒"
+  },
+  "black_small_square": {
+    "unicode": "25AA",
+    "unicode_alternates": ["25AA-FE0F"],
+    "name": "black small square",
+    "shortname": ":black_small_square:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": [],
+    "moji": "â–ª"
+  },
+  "black_square_button": {
+    "unicode": "1F532",
+    "unicode_alternates": [],
+    "name": "black square button",
+    "shortname": ":black_square_button:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["frame"],
+    "moji": "🔲"
+  },
+  "blossom": {
+    "unicode": "1F33C",
+    "unicode_alternates": [],
+    "name": "blossom",
+    "shortname": ":blossom:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["flowers", "nature", "yellow", "blossom", "daisy", "flower"],
+    "moji": "🌼"
+  },
+  "blowfish": {
+    "unicode": "1F421",
+    "unicode_alternates": [],
+    "name": "blowfish",
+    "shortname": ":blowfish:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["food", "nature", "ocean", "sea", "blowfish", "pufferfish", "puffer", "ballonfish", "toadfish", "fugu fish", "sushi"],
+    "moji": "🐡"
+  },
+  "blue_book": {
+    "unicode": "1F4D8",
+    "unicode_alternates": [],
+    "name": "blue book",
+    "shortname": ":blue_book:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["knowledge", "library", "read"],
+    "moji": "📘"
+  },
+  "blue_car": {
+    "unicode": "1F699",
+    "unicode_alternates": [],
+    "name": "recreational vehicle",
+    "shortname": ":blue_car:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["car", "suv", "car", "wagon", "automobile"],
+    "moji": "🚙"
+  },
+  "blue_heart": {
+    "unicode": "1F499",
+    "unicode_alternates": [],
+    "name": "blue heart",
+    "shortname": ":blue_heart:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["affection", "like", "love", "valentines", "blue", "heart", "love", "stability", "truth", "loyalty", "trust"],
+    "moji": "💙"
+  },
+  "blush": {
+    "unicode": "1F60A",
+    "unicode_alternates": [],
+    "name": "smiling face with smiling eyes",
+    "shortname": ":blush:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["crush", "embarrassed", "face", "flushed", "happy", "shy", "smile", "smiling", "smile", "smiley"],
+    "moji": "😊"
+  },
+  "boar": {
+    "unicode": "1F417",
+    "unicode_alternates": [],
+    "name": "boar",
+    "shortname": ":boar:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "nature"],
+    "moji": "🐗"
+  },
+  "bomb": {
+    "unicode": "1F4A3",
+    "unicode_alternates": [],
+    "name": "bomb",
+    "shortname": ":bomb:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["boom", "explode"],
+    "moji": "💣"
+  },
+  "book": {
+    "unicode": "1F4D6",
+    "unicode_alternates": [],
+    "name": "open book",
+    "shortname": ":book:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["library", "literature"],
+    "moji": "📖"
+  },
+  "book2": {
+    "unicode": "1F56E",
+    "unicode_alternates": [],
+    "name": "book",
+    "shortname": ":book2:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["library", "literature", "novel", "reading", "story"]
+  },
+  "bookmark": {
+    "unicode": "1F516",
+    "unicode_alternates": [],
+    "name": "bookmark",
+    "shortname": ":bookmark:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["favorite"],
+    "moji": "🔖"
+  },
+  "bookmark_tabs": {
+    "unicode": "1F4D1",
+    "unicode_alternates": [],
+    "name": "bookmark tabs",
+    "shortname": ":bookmark_tabs:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["favorite"],
+    "moji": "📑"
+  },
+  "books": {
+    "unicode": "1F4DA",
+    "unicode_alternates": [],
+    "name": "books",
+    "shortname": ":books:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["library", "literature"],
+    "moji": "📚"
+  },
+  "boom": {
+    "unicode": "1F4A5",
+    "unicode_alternates": [],
+    "name": "collision symbol",
+    "shortname": ":boom:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["bomb", "explode", "explosion", "boom", "bang", "collision", "fire", "emphasis", "wow", "bam"],
+    "moji": "💥"
+  },
+  "boot": {
+    "unicode": "1F462",
+    "unicode_alternates": [],
+    "name": "womans boots",
+    "shortname": ":boot:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["fashion", "shoes"],
+    "moji": "👢"
+  },
+  "bouquet": {
+    "unicode": "1F490",
+    "unicode_alternates": [],
+    "name": "bouquet",
+    "shortname": ":bouquet:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["flowers", "nature"],
+    "moji": "💐"
+  },
+  "bouquet2": {
+    "unicode": "1F395",
+    "unicode_alternates": [],
+    "name": "bouquet of flowers",
+    "shortname": ":bouquet2:",
+    "category": "celebration",
+    "aliases": [":bouquet_of_flowers:"],
+    "aliases_ascii": [],
+    "keywords": ["nature", "marriage", "wedding", "bride"]
+  },
+  "bow": {
+    "unicode": "1F647",
+    "unicode_alternates": [],
+    "name": "person bowing deeply",
+    "shortname": ":bow:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["boy", "male", "man", "sorry", "bow", "respect", "curtsy", "bend"],
+    "moji": "🙇"
+  },
+  "bowling": {
+    "unicode": "1F3B3",
+    "unicode_alternates": [],
+    "name": "bowling",
+    "shortname": ":bowling:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["fun", "play", "sports", "bowl", "bowling", "ball", "pin", "strike", "spare", "game"],
+    "moji": "🎳"
+  },
+  "boy": {
+    "unicode": "1F466",
+    "unicode_alternates": [],
+    "name": "boy",
+    "shortname": ":boy:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["guy", "male", "man"],
+    "moji": "👦"
+  },
+  "boys_symbol": {
+    "unicode": "1F6C9",
+    "unicode_alternates": [],
+    "name": "boys symbol",
+    "shortname": ":boys_symbol:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["male", "child"]
+  },
+  "bread": {
+    "unicode": "1F35E",
+    "unicode_alternates": [],
+    "name": "bread",
+    "shortname": ":bread:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["breakfast", "food", "toast", "wheat", "bread", "loaf", "yeast"],
+    "moji": "🍞"
+  },
+  "bride_with_veil": {
+    "unicode": "1F470",
+    "unicode_alternates": [],
+    "name": "bride with veil",
+    "shortname": ":bride_with_veil:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["couple", "marriage", "wedding", "bride", "wedding", "planning", "veil", "gown", "dress", "engagement", "white"],
+    "moji": "👰"
+  },
+  "bridge_at_night": {
+    "unicode": "1F309",
+    "unicode_alternates": [],
+    "name": "bridge at night",
+    "shortname": ":bridge_at_night:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["photo", "sanfrancisco", "bridge", "night", "water", "road", "evening", "suspension", "golden", "gate"],
+    "moji": "🌉"
+  },
+  "briefcase": {
+    "unicode": "1F4BC",
+    "unicode_alternates": [],
+    "name": "briefcase",
+    "shortname": ":briefcase:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["business", "documents", "work"],
+    "moji": "💼"
+  },
+  "broken_heart": {
+    "unicode": "1F494",
+    "unicode_alternates": [],
+    "name": "broken heart",
+    "shortname": ":broken_heart:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": ["</3"],
+    "keywords": ["sad", "sorry"],
+    "moji": "💔"
+  },
+  "bug": {
+    "unicode": "1F41B",
+    "unicode_alternates": [],
+    "name": "bug",
+    "shortname": ":bug:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["insect", "nature", "bug", "insect", "virus", "error"],
+    "moji": "🐛"
+  },
+  "bulb": {
+    "unicode": "1F4A1",
+    "unicode_alternates": [],
+    "name": "electric light bulb",
+    "shortname": ":bulb:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["electricity", "light", "idea", "bulb", "light"],
+    "moji": "💡"
+  },
+  "bullettrain_front": {
+    "unicode": "1F685",
+    "unicode_alternates": [],
+    "name": "high-speed train with bullet nose",
+    "shortname": ":bullettrain_front:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["transportation", "train", "bullet", "rail"],
+    "moji": "🚅"
+  },
+  "bullettrain_side": {
+    "unicode": "1F684",
+    "unicode_alternates": [],
+    "name": "high-speed train",
+    "shortname": ":bullettrain_side:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["transportation", "vehicle", "train", "bullet", "rail"],
+    "moji": "🚄"
+  },
+  "bullhorn": {
+    "unicode": "1F56B",
+    "unicode_alternates": [],
+    "name": "bullhorn",
+    "shortname": ":bullhorn:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["sound", "noise", "announcement", "megaphone"]
+  },
+  "bullhorn_waves": {
+    "unicode": "1F56C",
+    "unicode_alternates": [],
+    "name": "bullhorn with sound waves",
+    "shortname": ":bullhorn_waves:",
+    "category": "objects_symbols",
+    "aliases": [":bullhorn_with_sound_waves:"],
+    "aliases_ascii": [],
+    "keywords": ["sound", "noise", "announcement", "megaphone"]
+  },
+  "bus": {
+    "unicode": "1F68C",
+    "unicode_alternates": [],
+    "name": "bus",
+    "shortname": ":bus:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["car", "transportation", "vehicle", "bus", "school", "city", "transportation", "public"],
+    "moji": "🚌"
+  },
+  "busstop": {
+    "unicode": "1F68F",
+    "unicode_alternates": [],
+    "name": "bus stop",
+    "shortname": ":busstop:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["transportation", "bus", "stop", "city", "transport", "transportation"],
+    "moji": "🚏"
+  },
+  "bust_in_silhouette": {
+    "unicode": "1F464",
+    "unicode_alternates": [],
+    "name": "bust in silhouette",
+    "shortname": ":bust_in_silhouette:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["human", "man", "person", "user", "silhouette", "person", "user", "member", "account", "guest", "icon", "avatar", "profile", "me", "myself", "i"],
+    "moji": "👤"
+  },
+  "busts_in_silhouette": {
+    "unicode": "1F465",
+    "unicode_alternates": [],
+    "name": "busts in silhouette",
+    "shortname": ":busts_in_silhouette:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["group", "human", "man", "person", "team", "user", "silhouette", "silhouettes", "people", "user", "members", "accounts", "relationship", "shadow"],
+    "moji": "👥"
+  },
+  "cactus": {
+    "unicode": "1F335",
+    "unicode_alternates": [],
+    "name": "cactus",
+    "shortname": ":cactus:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["nature", "plant", "vegetable", "cactus", "desert", "drought", "spike", "poke"],
+    "moji": "🌵"
+  },
+  "cake": {
+    "unicode": "1F370",
+    "unicode_alternates": [],
+    "name": "shortcake",
+    "shortname": ":cake:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["desert", "food", "cake", "short", "dessert", "strawberry"],
+    "moji": "🍰"
+  },
+  "calculator": {
+    "unicode": "1F5A9",
+    "unicode_alternates": [],
+    "name": "pocket calculator",
+    "shortname": ":calculator:",
+    "category": "objects_symbols",
+    "aliases": [":pocket calculator:"],
+    "aliases_ascii": [],
+    "keywords": ["add", "subtract", "multiple", "divide", "scientific"]
+  },
+  "calendar": {
+    "unicode": "1F4C6",
+    "unicode_alternates": [],
+    "name": "tear-off calendar",
+    "shortname": ":calendar:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["schedule"],
+    "moji": "📆"
+  },
+  "calendar_spiral": {
+    "unicode": "1F5D3",
+    "unicode_alternates": [],
+    "name": "spiral calendar pad",
+    "shortname": ":calendar_spiral:",
+    "category": "objects_symbols",
+    "aliases": [":spiral_calendar_pad:"],
+    "aliases_ascii": [],
+    "keywords": ["schedule", "date", "day"]
+  },
+  "calling": {
+    "unicode": "1F4F2",
+    "unicode_alternates": [],
+    "name": "mobile phone with rightwards arrow at left",
+    "shortname": ":calling:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["incoming", "iphone"],
+    "moji": "📲"
+  },
+  "camel": {
+    "unicode": "1F42B",
+    "unicode_alternates": [],
+    "name": "bactrian camel",
+    "shortname": ":camel:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "hot", "nature", "bactrian", "camel", "hump", "desert", "central asia", "heat", "hot", "water", "hump day", "wednesday", "sex"],
+    "moji": "🐫"
+  },
+  "camera": {
+    "unicode": "1F4F7",
+    "unicode_alternates": [],
+    "name": "camera",
+    "shortname": ":camera:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["gadgets", "photo"],
+    "moji": "📷"
+  },
+  "camera_with_flash": {
+    "unicode": "1F4F8",
+    "unicode_alternates": [],
+    "name": "camera with flash",
+    "shortname": ":camera_with_flash:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["photo", "picture"]
+  },
+  "camping": {
+    "unicode": "1F3D5",
+    "unicode_alternates": [],
+    "name": "camping",
+    "shortname": ":camping:",
+    "category": "travel_places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["outdoors", "nature", "wilderness", "roughing", "activity"]
+  },
+  "cancellation_x": {
+    "unicode": "1F5D9",
+    "unicode_alternates": [],
+    "name": "cancellation x",
+    "shortname": ":cancellation_x:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["cancel", "stop", "delete"]
+  },
+  "cancer": {
+    "unicode": "264B",
+    "unicode_alternates": ["264B-FE0F"],
+    "name": "cancer",
+    "shortname": ":cancer:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["cancer", "crab", "astrology", "greek", "constellation", "stars", "zodiac", "sign", "sign", "zodiac", "horoscope"],
+    "moji": "♋"
+  },
+  "candle": {
+    "unicode": "1F56F",
+    "unicode_alternates": [],
+    "name": "candle",
+    "shortname": ":candle:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["light", "wax"]
+  },
+  "candy": {
+    "unicode": "1F36C",
+    "unicode_alternates": [],
+    "name": "candy",
+    "shortname": ":candy:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["desert", "snack", "candy", "sugar", "sweet", "hard"],
+    "moji": "🍬"
+  },
+  "capital_abcd": {
+    "unicode": "1F520",
+    "unicode_alternates": [],
+    "name": "input symbol for latin capital letters",
+    "shortname": ":capital_abcd:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["alphabet", "blue-square", "words"],
+    "moji": "🔠"
+  },
+  "capricorn": {
+    "unicode": "2651",
+    "unicode_alternates": ["2651-FE0F"],
+    "name": "capricorn",
+    "shortname": ":capricorn:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["capricorn", "sea-goat", "goat-horned", "astrology", "greek", "constellation", "stars", "zodiac", "sign", "sign", "zodiac", "horoscope"],
+    "moji": "♑"
+  },
+  "card_box": {
+    "unicode": "1F5C3",
+    "unicode_alternates": [],
+    "name": "card file box",
+    "shortname": ":card_box:",
+    "category": "objects_symbols",
+    "aliases": [":card_file_box:"],
+    "aliases_ascii": [],
+    "keywords": ["index", "organization"]
+  },
+  "card_index": {
+    "unicode": "1F4C7",
+    "unicode_alternates": [],
+    "name": "card index",
+    "shortname": ":card_index:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["business", "stationery"],
+    "moji": "📇"
+  },
+  "carousel_horse": {
+    "unicode": "1F3A0",
+    "unicode_alternates": [],
+    "name": "carousel horse",
+    "shortname": ":carousel_horse:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["carnival", "horse", "photo", "carousel", "horse", "amusement", "park", "ride", "entertainment", "park", "fair"],
+    "moji": "🎠"
+  },
+  "cartridge": {
+    "unicode": "1F5AD",
+    "unicode_alternates": [],
+    "name": "tape cartridge",
+    "shortname": ":cartridge:",
+    "category": "objects_symbols",
+    "aliases": [":tape_cartridge:"],
+    "aliases_ascii": [],
+    "keywords": ["oldschool", "save", "technology", "disk", "storage", "information", "computer", "drive", "megabyte"]
+  },
+  "cat": {
+    "unicode": "1F431",
+    "unicode_alternates": [],
+    "name": "cat face",
+    "shortname": ":cat:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "meow"],
+    "moji": "🐱"
+  },
+  "cat2": {
+    "unicode": "1F408",
+    "unicode_alternates": [],
+    "name": "cat",
+    "shortname": ":cat2:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "meow", "pet", "cat", "kitten", "meow"],
+    "moji": "🐈"
+  },
+  "celtic_cross": {
+    "unicode": "1F548",
+    "unicode_alternates": [],
+    "name": "celtic cross",
+    "shortname": ":celtic_cross:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["religion", "symbol"]
+  },
+  "chart": {
+    "unicode": "1F4B9",
+    "unicode_alternates": [],
+    "name": "chart with upwards trend and yen sign",
+    "shortname": ":chart:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["graph", "green-square"],
+    "moji": "💹"
+  },
+  "chart_with_downwards_trend": {
+    "unicode": "1F4C9",
+    "unicode_alternates": [],
+    "name": "chart with downwards trend",
+    "shortname": ":chart_with_downwards_trend:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["graph"],
+    "moji": "📉"
+  },
+  "chart_with_upwards_trend": {
+    "unicode": "1F4C8",
+    "unicode_alternates": [],
+    "name": "chart with upwards trend",
+    "shortname": ":chart_with_upwards_trend:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["graph"],
+    "moji": "📈"
+  },
+  "checkered_flag": {
+    "unicode": "1F3C1",
+    "unicode_alternates": [],
+    "name": "chequered flag",
+    "shortname": ":checkered_flag:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["contest", "finishline", "gokart", "rase", "checkered", "chequred", "race", "flag", "finish", "complete", "end"],
+    "moji": "🏁"
+  },
+  "cherries": {
+    "unicode": "1F352",
+    "unicode_alternates": [],
+    "name": "cherries",
+    "shortname": ":cherries:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["food", "fruit", "cherry", "cherries", "tree", "fruit", "pit"],
+    "moji": "🍒"
+  },
+  "cherry_blossom": {
+    "unicode": "1F338",
+    "unicode_alternates": [],
+    "name": "cherry blossom",
+    "shortname": ":cherry_blossom:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["flower", "nature", "plant", "cherry", "blossom", "tree", "flower"],
+    "moji": "🌸"
+  },
+  "chestnut": {
+    "unicode": "1F330",
+    "unicode_alternates": [],
+    "name": "chestnut",
+    "shortname": ":chestnut:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["food", "squirrel", "chestnut", "roasted", "food", "tree"],
+    "moji": "🌰"
+  },
+  "chicken": {
+    "unicode": "1F414",
+    "unicode_alternates": [],
+    "name": "chicken",
+    "shortname": ":chicken:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "cluck", "chicken", "hen", "poultry", "livestock"],
+    "moji": "🐔"
+  },
+  "children_crossing": {
+    "unicode": "1F6B8",
+    "unicode_alternates": [],
+    "name": "children crossing",
+    "shortname": ":children_crossing:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["school", "children", "kids", "caution", "crossing", "street", "crosswalk", "slow"],
+    "moji": "🚸"
+  },
+  "chipmunk": {
+    "unicode": "1F43F",
+    "unicode_alternates": [],
+    "name": "chipmunk",
+    "shortname": ":chipmunk:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "nature"]
+  },
+  "chocolate_bar": {
+    "unicode": "1F36B",
+    "unicode_alternates": [],
+    "name": "chocolate bar",
+    "shortname": ":chocolate_bar:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["desert", "food", "snack", "chocolate", "bar", "candy", "coca", "hershey&#039;s"],
+    "moji": "🍫"
+  },
+  "christmas_tree": {
+    "unicode": "1F384",
+    "unicode_alternates": [],
+    "name": "christmas tree",
+    "shortname": ":christmas_tree:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["celebration", "december", "festival", "vacation", "xmas", "christmas", "xmas", "santa", "holiday", "winter", "december", "santa", "evergreen", "ornaments", "jesus", "gifts", "presents"],
+    "moji": "🎄"
+  },
+  "church": {
+    "unicode": "26EA",
+    "unicode_alternates": ["26EA-FE0F"],
+    "name": "church",
+    "shortname": ":church:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["building", "christ", "religion"],
+    "moji": "⛪"
+  },
+  "cinema": {
+    "unicode": "1F3A6",
+    "unicode_alternates": [],
+    "name": "cinema",
+    "shortname": ":cinema:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blue-square", "film", "movie", "record", "cinema", "movie", "theater", "motion", "picture"],
+    "moji": "🎦"
+  },
+  "circus_tent": {
+    "unicode": "1F3AA",
+    "unicode_alternates": [],
+    "name": "circus tent",
+    "shortname": ":circus_tent:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["carnival", "festival", "party", "circus", "tent", "event", "carnival", "big", "top", "canvas"],
+    "moji": "🎪"
+  },
+  "city_dusk": {
+    "unicode": "1F306",
+    "unicode_alternates": [],
+    "name": "cityscape at dusk",
+    "shortname": ":city_dusk:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["photo", "city", "scape", "sunset", "dusk", "lights", "evening", "metropolitan", "night", "dark"],
+    "moji": "🌆"
+  },
+  "city_sunset": {
+    "unicode": "1F307",
+    "unicode_alternates": [],
+    "name": "sunset over buildings",
+    "shortname": ":city_sunset:",
+    "category": "places",
+    "aliases": [":city_sunrise:"],
+    "aliases_ascii": [],
+    "keywords": ["photo", "city", "scape", "sunrise", "dawn", "light", "morning", "metropolitan", "rise", "sun"],
+    "moji": "🌇"
+  },
+  "cityscape": {
+    "unicode": "1F3D9",
+    "unicode_alternates": [],
+    "name": "cityscape",
+    "shortname": ":cityscape:",
+    "category": "travel_places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["skyscraper", "city", "view", "lights", "buiildings", "metropolis"]
+  },
+  "clap": {
+    "unicode": "1F44F",
+    "unicode_alternates": [],
+    "name": "clapping hands sign",
+    "shortname": ":clap:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["applause", "congrats", "hands", "praise", "clapping", "appreciation", "approval", "sound", "encouragement", "enthusiasm"],
+    "moji": "👏"
+  },
+  "clapper": {
+    "unicode": "1F3AC",
+    "unicode_alternates": [],
+    "name": "clapper board",
+    "shortname": ":clapper:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["film", "movie", "record", "clapper", "board", "clapboard", "movie", "film", "take"],
+    "moji": "🎬"
+  },
+  "classical_building": {
+    "unicode": "1F3DB",
+    "unicode_alternates": [],
+    "name": "classical building",
+    "shortname": ":classical_building:",
+    "category": "travel_places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["government", "architecture", "history", "iconic", "genre"]
+  },
+  "clipboard": {
+    "unicode": "1F4CB",
+    "unicode_alternates": [],
+    "name": "clipboard",
+    "shortname": ":clipboard:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["documents", "stationery"],
+    "moji": "📋"
+  },
+  "clock": {
+    "unicode": "1F570",
+    "unicode_alternates": [],
+    "name": "mantlepiece clock",
+    "shortname": ":clock:",
+    "category": "objects_symbols",
+    "aliases": [":mantlepiece_clock:"],
+    "aliases_ascii": [],
+    "keywords": ["time"]
+  },
+  "clock1": {
+    "unicode": "1F550",
+    "unicode_alternates": [],
+    "name": "clock face one oclock",
+    "shortname": ":clock1:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["clock", "time"],
+    "moji": "🕐"
+  },
+  "clock10": {
+    "unicode": "1F559",
+    "unicode_alternates": [],
+    "name": "clock face ten oclock",
+    "shortname": ":clock10:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["clock", "time"],
+    "moji": "🕙"
+  },
+  "clock1030": {
+    "unicode": "1F565",
+    "unicode_alternates": [],
+    "name": "clock face ten-thirty",
+    "shortname": ":clock1030:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["clock", "time"],
+    "moji": "🕥"
+  },
+  "clock11": {
+    "unicode": "1F55A",
+    "unicode_alternates": [],
+    "name": "clock face eleven oclock",
+    "shortname": ":clock11:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["clock", "time"],
+    "moji": "🕚"
+  },
+  "clock1130": {
+    "unicode": "1F566",
+    "unicode_alternates": [],
+    "name": "clock face eleven-thirty",
+    "shortname": ":clock1130:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["clock", "time"],
+    "moji": "🕦"
+  },
+  "clock12": {
+    "unicode": "1F55B",
+    "unicode_alternates": [],
+    "name": "clock face twelve oclock",
+    "shortname": ":clock12:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["clock", "time"],
+    "moji": "🕛"
+  },
+  "clock1230": {
+    "unicode": "1F567",
+    "unicode_alternates": [],
+    "name": "clock face twelve-thirty",
+    "shortname": ":clock1230:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["clock", "time"]
+  },
+  "clock130": {
+    "unicode": "1F55C",
+    "unicode_alternates": [],
+    "name": "clock face one-thirty",
+    "shortname": ":clock130:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["clock", "time"],
+    "moji": "🕜"
+  },
+  "clock2": {
+    "unicode": "1F551",
+    "unicode_alternates": [],
+    "name": "clock face two oclock",
+    "shortname": ":clock2:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["clock", "time"],
+    "moji": "🕑"
+  },
+  "clock230": {
+    "unicode": "1F55D",
+    "unicode_alternates": [],
+    "name": "clock face two-thirty",
+    "shortname": ":clock230:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["clock", "time"],
+    "moji": "🕝"
+  },
+  "clock3": {
+    "unicode": "1F552",
+    "unicode_alternates": [],
+    "name": "clock face three oclock",
+    "shortname": ":clock3:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["clock", "time"],
+    "moji": "🕒"
+  },
+  "clock330": {
+    "unicode": "1F55E",
+    "unicode_alternates": [],
+    "name": "clock face three-thirty",
+    "shortname": ":clock330:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["clock", "time"],
+    "moji": "🕞"
+  },
+  "clock4": {
+    "unicode": "1F553",
+    "unicode_alternates": [],
+    "name": "clock face four oclock",
+    "shortname": ":clock4:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["clock", "time"],
+    "moji": "🕓"
+  },
+  "clock430": {
+    "unicode": "1F55F",
+    "unicode_alternates": [],
+    "name": "clock face four-thirty",
+    "shortname": ":clock430:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["clock", "time"],
+    "moji": "🕟"
+  },
+  "clock5": {
+    "unicode": "1F554",
+    "unicode_alternates": [],
+    "name": "clock face five oclock",
+    "shortname": ":clock5:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["clock", "time"],
+    "moji": "🕔"
+  },
+  "clock530": {
+    "unicode": "1F560",
+    "unicode_alternates": [],
+    "name": "clock face five-thirty",
+    "shortname": ":clock530:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["clock", "time"],
+    "moji": "🕠"
+  },
+  "clock6": {
+    "unicode": "1F555",
+    "unicode_alternates": [],
+    "name": "clock face six oclock",
+    "shortname": ":clock6:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["clock", "time"],
+    "moji": "🕕"
+  },
+  "clock630": {
+    "unicode": "1F561",
+    "unicode_alternates": [],
+    "name": "clock face six-thirty",
+    "shortname": ":clock630:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["clock", "time"],
+    "moji": "🕡"
+  },
+  "clock7": {
+    "unicode": "1F556",
+    "unicode_alternates": [],
+    "name": "clock face seven oclock",
+    "shortname": ":clock7:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["clock", "time"],
+    "moji": "🕖"
+  },
+  "clock730": {
+    "unicode": "1F562",
+    "unicode_alternates": [],
+    "name": "clock face seven-thirty",
+    "shortname": ":clock730:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["clock", "time"],
+    "moji": "🕢"
+  },
+  "clock8": {
+    "unicode": "1F557",
+    "unicode_alternates": [],
+    "name": "clock face eight oclock",
+    "shortname": ":clock8:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["clock", "time"],
+    "moji": "🕗"
+  },
+  "clock830": {
+    "unicode": "1F563",
+    "unicode_alternates": [],
+    "name": "clock face eight-thirty",
+    "shortname": ":clock830:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["clock", "time"],
+    "moji": "🕣"
+  },
+  "clock9": {
+    "unicode": "1F558",
+    "unicode_alternates": [],
+    "name": "clock face nine oclock",
+    "shortname": ":clock9:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["clock", "time"],
+    "moji": "🕘"
+  },
+  "clock930": {
+    "unicode": "1F564",
+    "unicode_alternates": [],
+    "name": "clock face nine-thirty",
+    "shortname": ":clock930:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["clock", "time"],
+    "moji": "🕤"
+  },
+  "clockwise_arrows": {
+    "unicode": "1F5D8",
+    "unicode_alternates": [],
+    "name": "clockwise right and left semicircle arrows",
+    "shortname": ":clockwise_arrows:",
+    "category": "objects_symbols",
+    "aliases": [":clockwise_right_and_left_semicircle_arrows:"],
+    "aliases_ascii": [],
+    "keywords": ["sync"]
+  },
+  "closed_book": {
+    "unicode": "1F4D5",
+    "unicode_alternates": [],
+    "name": "closed book",
+    "shortname": ":closed_book:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["knowledge", "library", "read"],
+    "moji": "📕"
+  },
+  "closed_lock_with_key": {
+    "unicode": "1F510",
+    "unicode_alternates": [],
+    "name": "closed lock with key",
+    "shortname": ":closed_lock_with_key:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["privacy", "security"],
+    "moji": "🔐"
+  },
+  "closed_umbrella": {
+    "unicode": "1F302",
+    "unicode_alternates": [],
+    "name": "closed umbrella",
+    "shortname": ":closed_umbrella:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["drizzle", "rain", "weather", "umbrella", "closed", "rain", "moisture", "protection", "sun", "ultraviolet", "uv"],
+    "moji": "🌂"
+  },
+  "cloud": {
+    "unicode": "2601",
+    "unicode_alternates": ["2601-FE0F"],
+    "name": "cloud",
+    "shortname": ":cloud:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["sky", "weather"],
+    "moji": "☁"
+  },
+  "cloud_lightning": {
+    "unicode": "1F329",
+    "unicode_alternates": [],
+    "name": "cloud with lightning",
+    "shortname": ":cloud_lightning:",
+    "category": "nature",
+    "aliases": [":cloud_with_lightning:"],
+    "aliases_ascii": [],
+    "keywords": ["weather", "thunder"]
+  },
+  "cloud_rain": {
+    "unicode": "1F327",
+    "unicode_alternates": [],
+    "name": "cloud with rain",
+    "shortname": ":cloud_rain:",
+    "category": "nature",
+    "aliases": [":cloud_with_rain:"],
+    "aliases_ascii": [],
+    "keywords": ["weather", "wet"]
+  },
+  "cloud_snow": {
+    "unicode": "1F328",
+    "unicode_alternates": [],
+    "name": "cloud with snow",
+    "shortname": ":cloud_snow:",
+    "category": "nature",
+    "aliases": [":cloud_with_snow:"],
+    "aliases_ascii": [],
+    "keywords": ["weather", "cold"]
+  },
+  "cloud_tornado": {
+    "unicode": "1F32A",
+    "unicode_alternates": [],
+    "name": "cloud with tornado",
+    "shortname": ":cloud_tornado:",
+    "category": "nature",
+    "aliases": [":cloud_with_tornado:"],
+    "aliases_ascii": [],
+    "keywords": ["weather", "destruction", "funnel"]
+  },
+  "clubs": {
+    "unicode": "2663",
+    "unicode_alternates": ["2663-FE0F"],
+    "name": "black club suit",
+    "shortname": ":clubs:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["cards", "poker"],
+    "moji": "♣"
+  },
+  "cocktail": {
+    "unicode": "1F378",
+    "unicode_alternates": [],
+    "name": "cocktail glass",
+    "shortname": ":cocktail:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["alcohol", "beverage", "drink", "drunk", "cocktail", "mixed", "drink", "alcohol", "glass", "martini", "bar"],
+    "moji": "🍸"
+  },
+  "coffee": {
+    "unicode": "2615",
+    "unicode_alternates": ["2615-FE0F"],
+    "name": "hot beverage",
+    "shortname": ":coffee:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["beverage", "cafe", "drink", "espresso"],
+    "moji": "☕"
+  },
+  "cold_sweat": {
+    "unicode": "1F630",
+    "unicode_alternates": [],
+    "name": "face with open mouth and cold sweat",
+    "shortname": ":cold_sweat:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["face", "nervous", "sweat", "exasperated", "frustrated"],
+    "moji": "😰"
+  },
+  "compression": {
+    "unicode": "1F5DC",
+    "unicode_alternates": [],
+    "name": "compression",
+    "shortname": ":compression:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["reduce"]
+  },
+  "computer": {
+    "unicode": "1F4BB",
+    "unicode_alternates": [],
+    "name": "personal computer",
+    "shortname": ":computer:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["laptop", "tech"],
+    "moji": "💻"
+  },
+  "computer_old": {
+    "unicode": "1F5B3",
+    "unicode_alternates": [],
+    "name": "old personal computer",
+    "shortname": ":computer_old:",
+    "category": "objects_symbols",
+    "aliases": [":old_personal_computer:"],
+    "aliases_ascii": [],
+    "keywords": ["cpu", "terminal"]
+  },
+  "confetti_ball": {
+    "unicode": "1F38A",
+    "unicode_alternates": [],
+    "name": "confetti ball",
+    "shortname": ":confetti_ball:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["festival", "party", "party", "congratulations", "confetti", "ball", "celebrate", "win", "birthday", "new years", "wedding"],
+    "moji": "🎊"
+  },
+  "confounded": {
+    "unicode": "1F616",
+    "unicode_alternates": [],
+    "name": "confounded face",
+    "shortname": ":confounded:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["confused", "face", "sick", "unwell", "confound", "amaze", "perplex", "puzzle", "mystify"],
+    "moji": "😖"
+  },
+  "confused": {
+    "unicode": "1F615",
+    "unicode_alternates": [],
+    "name": "confused face",
+    "shortname": ":confused:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [">:\\", ">:/", ":-/", ":-.", ":/", ":\\", "=/", "=\\", ":L", "=L"],
+    "keywords": ["confused", "confuse", "daze", "perplex", "puzzle", "indifference", "skeptical", "undecided", "uneasy", "hesitant"],
+    "moji": "😕"
+  },
+  "congratulations": {
+    "unicode": "3297",
+    "unicode_alternates": ["3297-FE0F"],
+    "name": "circled ideograph congratulation",
+    "shortname": ":congratulations:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["chinese", "japanese", "kanji"],
+    "moji": "㊗"
+  },
+  "construction": {
+    "unicode": "1F6A7",
+    "unicode_alternates": [],
+    "name": "construction sign",
+    "shortname": ":construction:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["caution", "progress", "wip"],
+    "moji": "🚧"
+  },
+  "construction_worker": {
+    "unicode": "1F477",
+    "unicode_alternates": [],
+    "name": "construction worker",
+    "shortname": ":construction_worker:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["human", "male", "man", "wip"],
+    "moji": "👷"
+  },
+  "control_knobs": {
+    "unicode": "1F39B",
+    "unicode_alternates": [],
+    "name": "control knobs",
+    "shortname": ":control_knobs:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["dial"]
+  },
+  "contruction_site": {
+    "unicode": "1F3D7",
+    "unicode_alternates": [],
+    "name": "building construction",
+    "shortname": ":contruction_site:",
+    "category": "travel_places",
+    "aliases": [":building_construction:"],
+    "aliases_ascii": [],
+    "keywords": ["site", "work"]
+  },
+  "convenience_store": {
+    "unicode": "1F3EA",
+    "unicode_alternates": [],
+    "name": "convenience store",
+    "shortname": ":convenience_store:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["building"],
+    "moji": "🏪"
+  },
+  "cookie": {
+    "unicode": "1F36A",
+    "unicode_alternates": [],
+    "name": "cookie",
+    "shortname": ":cookie:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["chocolate", "food", "oreo", "snack", "cookie", "dessert", "biscuit", "sweet", "chocolate"],
+    "moji": "🍪"
+  },
+  "cool": {
+    "unicode": "1F192",
+    "unicode_alternates": [],
+    "name": "squared cool",
+    "shortname": ":cool:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blue-square", "words"],
+    "moji": "🆒"
+  },
+  "cop": {
+    "unicode": "1F46E",
+    "unicode_alternates": [],
+    "name": "police officer",
+    "shortname": ":cop:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["arrest", "enforcement", "law", "man", "police"],
+    "moji": "👮"
+  },
+  "copyright": {
+    "moji": "©",
+    "unicode": "00A9",
+    "unicode_alternates": [],
+    "name": "copyright sign",
+    "shortname": ":copyright:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["ip", "license"]
+  },
+  "corn": {
+    "unicode": "1F33D",
+    "unicode_alternates": [],
+    "name": "ear of maize",
+    "shortname": ":corn:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["food", "plant", "vegetable", "corn", "maize", "food", "iowa", "kernel", "popcorn", "husk", "yellow", "stalk", "cob", "ear"],
+    "moji": "🌽"
+  },
+  "couch": {
+    "unicode": "1F6CB",
+    "unicode_alternates": [],
+    "name": "couch and lamp",
+    "shortname": ":couch:",
+    "category": "travel_places",
+    "aliases": [":couch_and_lamp:"],
+    "aliases_ascii": [],
+    "keywords": ["lounge", "sectional", "sofa", "loveseat", "leather", "microfiber", "sit", "relax"]
+  },
+  "couple": {
+    "unicode": "1F46B",
+    "unicode_alternates": [],
+    "name": "man and woman holding hands",
+    "shortname": ":couple:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["affection", "date", "dating", "human", "like", "love", "marriage", "people", "valentines"],
+    "moji": "👫"
+  },
+  "couple_mm": {
+    "unicode": "1F468-2764-1F468",
+    "unicode_alternates": ["1F468-200D-2764-FE0F-200D-1F468"],
+    "name": "couple (man,man)",
+    "shortname": ":couple_mm:",
+    "category": "people",
+    "aliases": [":couple_with_heart_mm:"],
+    "aliases_ascii": [],
+    "keywords": ["affection", "dating", "human", "like", "love", "marriage", "valentines"]
+  },
+  "couple_with_heart": {
+    "unicode": "1F491",
+    "unicode_alternates": [],
+    "name": "couple with heart",
+    "shortname": ":couple_with_heart:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["affection", "dating", "human", "like", "love", "marriage", "valentines"],
+    "moji": "💑"
+  },
+  "couple_ww": {
+    "unicode": "1F469-2764-1F469",
+    "unicode_alternates": ["1F469-200D-2764-FE0F-200D-1F469"],
+    "name": "couple (woman,woman)",
+    "shortname": ":couple_ww:",
+    "category": "people",
+    "aliases": [":couple_with_heart_ww:"],
+    "aliases_ascii": [],
+    "keywords": ["affection", "dating", "human", "like", "love", "marriage", "valentines"]
+  },
+  "couplekiss": {
+    "unicode": "1F48F",
+    "unicode_alternates": [],
+    "name": "kiss",
+    "shortname": ":couplekiss:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["dating", "like", "love", "marriage", "valentines"],
+    "moji": "💏"
+  },
+  "cow": {
+    "unicode": "1F42E",
+    "unicode_alternates": [],
+    "name": "cow face",
+    "shortname": ":cow:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "beef", "ox"],
+    "moji": "🐮"
+  },
+  "cow2": {
+    "unicode": "1F404",
+    "unicode_alternates": [],
+    "name": "cow",
+    "shortname": ":cow2:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "beef", "nature", "ox", "cow", "milk", "dairy", "beef", "bessie", "moo"],
+    "moji": "🐄"
+  },
+  "crayon": {
+    "unicode": "1F58D",
+    "unicode_alternates": [],
+    "name": "lower left crayon",
+    "shortname": ":crayon:",
+    "category": "objects_symbols",
+    "aliases": [":lower_left_crayon:"],
+    "aliases_ascii": [],
+    "keywords": ["write", "draw", "color", "wax"]
+  },
+  "credit_card": {
+    "unicode": "1F4B3",
+    "unicode_alternates": [],
+    "name": "credit card",
+    "shortname": ":credit_card:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["bill", "dollar", "money", "pay", "payment", "credit", "card", "loan", "purchase", "shopping", "mastercard", "visa", "american express", "wallet", "signature"],
+    "moji": "💳"
+  },
+  "crescent_moon": {
+    "unicode": "1F319",
+    "unicode_alternates": [],
+    "name": "crescent moon",
+    "shortname": ":crescent_moon:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["night", "moon", "crescent", "waxing", "sky", "night", "cheese", "phase"],
+    "moji": "🌙"
+  },
+  "crocodile": {
+    "unicode": "1F40A",
+    "unicode_alternates": [],
+    "name": "crocodile",
+    "shortname": ":crocodile:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "nature", "crocodile", "croc", "alligator", "gator", "cranky"],
+    "moji": "🐊"
+  },
+  "cross_heavy": {
+    "unicode": "1F547",
+    "unicode_alternates": [],
+    "name": "heavy latin cross",
+    "shortname": ":cross_heavy:",
+    "category": "objects_symbols",
+    "aliases": [":heavy_latin_cross:"],
+    "aliases_ascii": [],
+    "keywords": ["religion", "symbol"]
+  },
+  "cross_white": {
+    "unicode": "1F546",
+    "unicode_alternates": [],
+    "name": "white latin cross",
+    "shortname": ":cross_white:",
+    "category": "objects_symbols",
+    "aliases": [":white_latin_cross:"],
+    "aliases_ascii": [],
+    "keywords": ["religion", "symbol"]
+  },
+  "crossbones": {
+    "unicode": "1F571",
+    "unicode_alternates": [],
+    "name": "black skull and crossbones",
+    "shortname": ":crossbones:",
+    "category": "objects_symbols",
+    "aliases": [":black_skull_and_crossbones:"],
+    "aliases_ascii": [],
+    "keywords": ["poison", "danger", "death"]
+  },
+  "crossed_flags": {
+    "unicode": "1F38C",
+    "unicode_alternates": [],
+    "name": "crossed flags",
+    "shortname": ":crossed_flags:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["japan"],
+    "moji": "🎌"
+  },
+  "crown": {
+    "unicode": "1F451",
+    "unicode_alternates": [],
+    "name": "crown",
+    "shortname": ":crown:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["king", "kod", "leader", "royalty"],
+    "moji": "👑"
+  },
+  "cruise_ship": {
+    "unicode": "1F6F3",
+    "unicode_alternates": [],
+    "name": "passenger ship",
+    "shortname": ":cruise_ship:",
+    "category": "travel_places",
+    "aliases": [":passenger_ship:"],
+    "aliases_ascii": [],
+    "keywords": ["titanic", "transportation", "boat"]
+  },
+  "cry": {
+    "unicode": "1F622",
+    "unicode_alternates": [],
+    "name": "crying face",
+    "shortname": ":cry:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [":'(", ":'-(", ";(", ";-("],
+    "keywords": ["face", "sad", "sad", "cry", "tear", "weep", "tears"],
+    "moji": "😢"
+  },
+  "crying_cat_face": {
+    "unicode": "1F63F",
+    "unicode_alternates": [],
+    "name": "crying cat face",
+    "shortname": ":crying_cat_face:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "cats", "sad", "tears", "weep", "cry", "cat", "sob", "tears", "sad", "melancholy", "morn", "somber", "hurt"],
+    "moji": "😿"
+  },
+  "crystal_ball": {
+    "unicode": "1F52E",
+    "unicode_alternates": [],
+    "name": "crystal ball",
+    "shortname": ":crystal_ball:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["disco", "party"],
+    "moji": "🔮"
+  },
+  "cupid": {
+    "unicode": "1F498",
+    "unicode_alternates": [],
+    "name": "heart with arrow",
+    "shortname": ":cupid:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["affection", "heart", "like", "love", "valentines"],
+    "moji": "💘"
+  },
+  "curly_loop": {
+    "unicode": "27B0",
+    "unicode_alternates": [],
+    "name": "curly loop",
+    "shortname": ":curly_loop:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["scribble"],
+    "moji": "âž°"
+  },
+  "currency_exchange": {
+    "unicode": "1F4B1",
+    "unicode_alternates": [],
+    "name": "currency exchange",
+    "shortname": ":currency_exchange:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["dollar", "money", "travel"],
+    "moji": "💱"
+  },
+  "curry": {
+    "unicode": "1F35B",
+    "unicode_alternates": [],
+    "name": "curry and rice",
+    "shortname": ":curry:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["food", "hot", "indian", "spicy", "curry", "spice", "flavor", "food", "meal"],
+    "moji": "🍛"
+  },
+  "custard": {
+    "unicode": "1F36E",
+    "unicode_alternates": [],
+    "name": "custard",
+    "shortname": ":custard:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["desert", "food", "custard", "cream", "rich", "butter", "dessert", "crème", "brûlée", "french"],
+    "moji": "🍮"
+  },
+  "customs": {
+    "unicode": "1F6C3",
+    "unicode_alternates": [],
+    "name": "customs",
+    "shortname": ":customs:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["border", "passport", "customs", "travel", "foreign", "goods", "check", "authority", "government"],
+    "moji": "🛃"
+  },
+  "cyclone": {
+    "moji": "🌀",
+    "unicode": "1F300",
+    "unicode_alternates": [],
+    "name": "cyclone",
+    "shortname": ":cyclone:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blue", "cloud", "swirl", "weather", "cyclone", "hurricane", "typhoon", "storm", "ocean"]
+  },
+  "dagger": {
+    "unicode": "1F5E1",
+    "unicode_alternates": [],
+    "name": "dagger knife",
+    "shortname": ":dagger:",
+    "category": "objects_symbols",
+    "aliases": [":dagger_knife:"],
+    "aliases_ascii": [],
+    "keywords": ["blade", "knife"]
+  },
+  "dancer": {
+    "unicode": "1F483",
+    "unicode_alternates": [],
+    "name": "dancer",
+    "shortname": ":dancer:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["female", "fun", "girl", "woman", "dance", "dancer", "dress", "fancy", "boogy", "party", "celebrate", "ballet", "tango", "cha cha", "music"],
+    "moji": "💃"
+  },
+  "dancers": {
+    "unicode": "1F46F",
+    "unicode_alternates": [],
+    "name": "woman with bunny ears",
+    "shortname": ":dancers:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["bunny", "female", "girls", "women", "dancing", "dancers", "showgirl", "playboy", "costume", "bunny", "cancan"],
+    "moji": "👯"
+  },
+  "dango": {
+    "unicode": "1F361",
+    "unicode_alternates": [],
+    "name": "dango",
+    "shortname": ":dango:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["food", "dango", "japanese", "dumpling", "mochi", "balls", "skewer"],
+    "moji": "🍡"
+  },
+  "dark_sunglasses": {
+    "unicode": "1F576",
+    "unicode_alternates": [],
+    "name": "dark sunglasses",
+    "shortname": ":dark_sunglasses:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["shades", "eyes"]
+  },
+  "dart": {
+    "unicode": "1F3AF",
+    "unicode_alternates": [],
+    "name": "direct hit",
+    "shortname": ":dart:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["bar", "game", "direct", "hit", "bullseye", "dart", "archery", "game", "fletching", "arrow", "sport"],
+    "moji": "🎯"
+  },
+  "dash": {
+    "unicode": "1F4A8",
+    "unicode_alternates": [],
+    "name": "dash symbol",
+    "shortname": ":dash:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["air", "fast", "shoo", "wind"],
+    "moji": "💨"
+  },
+  "date": {
+    "unicode": "1F4C5",
+    "unicode_alternates": [],
+    "name": "calendar",
+    "shortname": ":date:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["calendar", "schedule"],
+    "moji": "📅"
+  },
+  "deciduous_tree": {
+    "unicode": "1F333",
+    "unicode_alternates": [],
+    "name": "deciduous tree",
+    "shortname": ":deciduous_tree:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["nature", "plant", "deciduous", "tree", "leaves", "fall", "color"],
+    "moji": "🌳"
+  },
+  "department_store": {
+    "unicode": "1F3EC",
+    "unicode_alternates": [],
+    "name": "department store",
+    "shortname": ":department_store:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["building", "mall", "shopping", "department", "store", "retail", "sale", "merchandise"],
+    "moji": "🏬"
+  },
+  "descending_notes": {
+    "unicode": "1F39D",
+    "unicode_alternates": [],
+    "name": "beamed descending musical notes",
+    "shortname": ":descending_notes:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["score", "music", "sound", "tone"]
+  },
+  "desert": {
+    "unicode": "1F3DC",
+    "unicode_alternates": [],
+    "name": "desert",
+    "shortname": ":desert:",
+    "category": "travel_places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["hot", "dry", "sandy", "cactus", "sunny", "barren"]
+  },
+  "desktop": {
+    "unicode": "1F5A5",
+    "unicode_alternates": [],
+    "name": "desktop computer",
+    "shortname": ":desktop:",
+    "category": "objects_symbols",
+    "aliases": [":desktop_computer:"],
+    "aliases_ascii": [],
+    "keywords": ["cpu"]
+  },
+  "desktop_window": {
+    "unicode": "1F5D4",
+    "unicode_alternates": [],
+    "name": "desktop window",
+    "shortname": ":desktop_window:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["computer"]
+  },
+  "diamond_shape_with_a_dot_inside": {
+    "unicode": "1F4A0",
+    "unicode_alternates": [],
+    "name": "diamond shape with a dot inside",
+    "shortname": ":diamond_shape_with_a_dot_inside:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["diamond", "cute", "cuteness", "kawaii", "japanese", "glyph", "adorable"],
+    "moji": "💠"
+  },
+  "diamonds": {
+    "unicode": "2666",
+    "unicode_alternates": ["2666-FE0F"],
+    "name": "black diamond suit",
+    "shortname": ":diamonds:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["cards", "poker"],
+    "moji": "♦"
+  },
+  "disappointed": {
+    "unicode": "1F61E",
+    "unicode_alternates": [],
+    "name": "disappointed face",
+    "shortname": ":disappointed:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [">:[", ":-(", ":(", ":-[", ":[", "=("],
+    "keywords": ["disappointed", "disappoint", "frown", "depressed", "discouraged", "face", "sad", "upset"],
+    "moji": "😞"
+  },
+  "disappointed_relieved": {
+    "unicode": "1F625",
+    "unicode_alternates": [],
+    "name": "disappointed but relieved face",
+    "shortname": ":disappointed_relieved:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["face", "nervous", "phew", "sweat", "disappoint", "relief"],
+    "moji": "😥"
+  },
+  "dividers": {
+    "unicode": "1F5C2",
+    "unicode_alternates": [],
+    "name": "card index dividers",
+    "shortname": ":dividers:",
+    "category": "objects_symbols",
+    "aliases": [":card_index_dividers:"],
+    "aliases_ascii": [],
+    "keywords": ["stationery", "rolodex"]
+  },
+  "dizzy": {
+    "unicode": "1F4AB",
+    "unicode_alternates": [],
+    "name": "dizzy symbol",
+    "shortname": ":dizzy:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["shoot", "sparkle", "star", "dizzy", "drunk", "sick", "intoxicated", "squeans", "starburst", "star"],
+    "moji": "💫"
+  },
+  "dizzy_face": {
+    "unicode": "1F635",
+    "unicode_alternates": [],
+    "name": "dizzy face",
+    "shortname": ":dizzy_face:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": ["#-)", "#)", "%-)", "%)", "X)", "X-)"],
+    "keywords": ["dizzy", "drunk", "inebriated", "face", "spent", "unconscious", "xox"],
+    "moji": "😵"
+  },
+  "do_not_litter": {
+    "unicode": "1F6AF",
+    "unicode_alternates": [],
+    "name": "do not litter symbol",
+    "shortname": ":do_not_litter:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["bin", "garbage", "trash", "litter", "garbage", "waste", "no", "can", "trash"],
+    "moji": "🚯"
+  },
+  "document": {
+    "unicode": "1F5CE",
+    "unicode_alternates": [],
+    "name": "document",
+    "shortname": ":document:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["page"]
+  },
+  "document_text": {
+    "unicode": "1F5B9",
+    "unicode_alternates": [],
+    "name": "document with text",
+    "shortname": ":document_text:",
+    "category": "objects_symbols",
+    "aliases": [":document_with_text:"],
+    "aliases_ascii": [],
+    "keywords": ["page"]
+  },
+  "dog": {
+    "unicode": "1F436",
+    "unicode_alternates": [],
+    "name": "dog face",
+    "shortname": ":dog:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "friend", "nature", "woof"],
+    "moji": "🐶"
+  },
+  "dog2": {
+    "unicode": "1F415",
+    "unicode_alternates": [],
+    "name": "dog",
+    "shortname": ":dog2:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "doge", "friend", "nature", "pet", "dog", "puppy", "pet", "friend", "woof", "bark", "fido"],
+    "moji": "🐕"
+  },
+  "dollar": {
+    "unicode": "1F4B5",
+    "unicode_alternates": [],
+    "name": "banknote with dollar sign",
+    "shortname": ":dollar:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["bill", "currency", "money", "dollar", "united states", "canada", "australia", "banknote", "money", "currency", "paper", "cash", "bills"],
+    "moji": "💵"
+  },
+  "dolls": {
+    "unicode": "1F38E",
+    "unicode_alternates": [],
+    "name": "japanese dolls",
+    "shortname": ":dolls:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["japanese", "kimono", "toy", "dolls", "japan", "japanese", "day", "girls", "emperor", "empress", "pray", "blessing", "imperial", "family", "royal"],
+    "moji": "🎎"
+  },
+  "dolphin": {
+    "unicode": "1F42C",
+    "unicode_alternates": [],
+    "name": "dolphin",
+    "shortname": ":dolphin:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "fins", "fish", "flipper", "nature", "ocean", "sea"],
+    "moji": "🐬"
+  },
+  "door": {
+    "unicode": "1F6AA",
+    "unicode_alternates": [],
+    "name": "door",
+    "shortname": ":door:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["entry", "exit", "house", "door", "doorway", "entrance", "enter", "exit", "entry"],
+    "moji": "🚪"
+  },
+  "doughnut": {
+    "unicode": "1F369",
+    "unicode_alternates": [],
+    "name": "doughnut",
+    "shortname": ":doughnut:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["desert", "food", "snack", "sweet", "doughnut", "donut", "pastry", "fried", "dessert", "breakfast", "police", "homer", "sweet"],
+    "moji": "🍩"
+  },
+  "dove": {
+    "unicode": "1F54A",
+    "unicode_alternates": [],
+    "name": "dove of peace",
+    "shortname": ":dove:",
+    "category": "objects_symbols",
+    "aliases": [":dove_of_peace:"],
+    "aliases_ascii": [],
+    "keywords": ["symbol", "bird"]
+  },
+  "dragon": {
+    "unicode": "1F409",
+    "unicode_alternates": [],
+    "name": "dragon",
+    "shortname": ":dragon:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "chinese", "green", "myth", "nature", "dragon", "fire", "legendary", "myth"],
+    "moji": "🐉"
+  },
+  "dragon_face": {
+    "unicode": "1F432",
+    "unicode_alternates": [],
+    "name": "dragon face",
+    "shortname": ":dragon_face:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "chinese", "green", "myth", "nature", "dragon", "head", "fire", "legendary", "myth"],
+    "moji": "🐲"
+  },
+  "dress": {
+    "unicode": "1F457",
+    "unicode_alternates": [],
+    "name": "dress",
+    "shortname": ":dress:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["clothes", "fashion"],
+    "moji": "👗"
+  },
+  "dromedary_camel": {
+    "unicode": "1F42A",
+    "unicode_alternates": [],
+    "name": "dromedary camel",
+    "shortname": ":dromedary_camel:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "desert", "hot", "dromedary", "camel", "hump", "desert", "middle east", "heat", "hot", "water", "hump day", "wednesday", "sex"],
+    "moji": "🐪"
+  },
+  "droplet": {
+    "unicode": "1F4A7",
+    "unicode_alternates": [],
+    "name": "droplet",
+    "shortname": ":droplet:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["drip", "faucet", "water", "drop", "droplet", "h20", "water", "aqua", "tear", "sweat", "rain", "moisture", "wet", "moist", "spit"],
+    "moji": "💧"
+  },
+  "dvd": {
+    "unicode": "1F4C0",
+    "unicode_alternates": [],
+    "name": "dvd",
+    "shortname": ":dvd:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["cd", "disc", "disk"],
+    "moji": "📀"
+  },
+  "e-mail": {
+    "unicode": "1F4E7",
+    "unicode_alternates": [],
+    "name": "e-mail symbol",
+    "shortname": ":e-mail:",
+    "category": "objects",
+    "aliases": [":email:"],
+    "aliases_ascii": [],
+    "keywords": ["communication", "inbox"],
+    "moji": "📧"
+  },
+  "ear": {
+    "unicode": "1F442",
+    "unicode_alternates": [],
+    "name": "ear",
+    "shortname": ":ear:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["face", "hear", "listen", "sound"],
+    "moji": "👂"
+  },
+  "ear_of_rice": {
+    "unicode": "1F33E",
+    "unicode_alternates": [],
+    "name": "ear of rice",
+    "shortname": ":ear_of_rice:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["nature", "plant", "ear", "rice", "food", "plant", "seed"],
+    "moji": "🌾"
+  },
+  "earth_africa": {
+    "unicode": "1F30D",
+    "unicode_alternates": [],
+    "name": "earth globe europe-africa",
+    "shortname": ":earth_africa:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["globe", "international", "world", "earth", "globe", "space", "planet", "africa", "europe", "home"],
+    "moji": "🌍"
+  },
+  "earth_americas": {
+    "unicode": "1F30E",
+    "unicode_alternates": [],
+    "name": "earth globe americas",
+    "shortname": ":earth_americas:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["USA", "globe", "international", "world", "earth", "globe", "space", "planet", "north", "south", "america", "americas", "home"],
+    "moji": "🌎"
+  },
+  "earth_asia": {
+    "unicode": "1F30F",
+    "unicode_alternates": [],
+    "name": "earth globe asia-australia",
+    "shortname": ":earth_asia:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["east", "globe", "international", "world", "earth", "globe", "space", "planet", "asia", "australia", "home"],
+    "moji": "🌏"
+  },
+  "egg": {
+    "unicode": "1F373",
+    "unicode_alternates": [],
+    "name": "cooking",
+    "shortname": ":egg:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["breakfast", "food", "egg", "fry", "pan", "flat", "cook", "frying", "cooking", "utensil"],
+    "moji": "🍳"
+  },
+  "eggplant": {
+    "unicode": "1F346",
+    "unicode_alternates": [],
+    "name": "aubergine",
+    "shortname": ":eggplant:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["aubergine", "food", "nature", "vegetable", "eggplant", "aubergine", "fruit", "purple", "penis"],
+    "moji": "🍆"
+  },
+  "eight": {
+    "moji": "8️⃣",
+    "unicode": "0038-20E3",
+    "unicode_alternates": ["0038-FE0F-20E3"],
+    "name": "digit eight",
+    "shortname": ":eight:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["8", "blue-square", "numbers"]
+  },
+  "eight_pointed_black_star": {
+    "unicode": "2734",
+    "unicode_alternates": ["2734-FE0F"],
+    "name": "eight pointed black star",
+    "shortname": ":eight_pointed_black_star:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": [],
+    "moji": "✴"
+  },
+  "eight_spoked_asterisk": {
+    "unicode": "2733",
+    "unicode_alternates": ["2733-FE0F"],
+    "name": "eight spoked asterisk",
+    "shortname": ":eight_spoked_asterisk:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["green-square", "sparkle", "star"],
+    "moji": "✳"
+  },
+  "electric_plug": {
+    "unicode": "1F50C",
+    "unicode_alternates": [],
+    "name": "electric plug",
+    "shortname": ":electric_plug:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["charger", "power"],
+    "moji": "🔌"
+  },
+  "elephant": {
+    "unicode": "1F418",
+    "unicode_alternates": [],
+    "name": "elephant",
+    "shortname": ":elephant:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "nature", "nose", "thailand"],
+    "moji": "🐘"
+  },
+  "end": {
+    "unicode": "1F51A",
+    "unicode_alternates": [],
+    "name": "end with leftwards arrow above",
+    "shortname": ":end:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["arrow", "words"],
+    "moji": "🔚"
+  },
+  "envelope": {
+    "unicode": "2709",
+    "unicode_alternates": ["2709-FE0F"],
+    "name": "envelope",
+    "shortname": ":envelope:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["communication", "letter", "mail", "postal"],
+    "moji": "✉"
+  },
+  "envelope_back": {
+    "unicode": "1F582",
+    "unicode_alternates": [],
+    "name": "back of envelope",
+    "shortname": ":envelope_back:",
+    "category": "objects_symbols",
+    "aliases": [":back_of_envelope:"],
+    "aliases_ascii": [],
+    "keywords": ["communication", "letter", "mail", "postal"]
+  },
+  "envelope_flying": {
+    "unicode": "1F585",
+    "unicode_alternates": [],
+    "name": "flying envelope",
+    "shortname": ":envelope_flying:",
+    "category": "objects_symbols",
+    "aliases": [":flying_envelope:"],
+    "aliases_ascii": [],
+    "keywords": ["communication", "letter", "mail", "postal"]
+  },
+  "envelope_stamped": {
+    "unicode": "1F583",
+    "unicode_alternates": [],
+    "name": "stamped envelope",
+    "shortname": ":envelope_stamped:",
+    "category": "objects_symbols",
+    "aliases": [":stamped_envelope:"],
+    "aliases_ascii": [],
+    "keywords": ["communication", "letter", "mail", "postal"]
+  },
+  "envelope_stamped_pen": {
+    "unicode": "1F586",
+    "unicode_alternates": [],
+    "name": "pen over stamped envelope",
+    "shortname": ":envelope_stamped_pen:",
+    "category": "objects_symbols",
+    "aliases": [":pen_over_stamped_envelope:"],
+    "aliases_ascii": [],
+    "keywords": ["communication", "letter", "mail", "postal"]
+  },
+  "envelope_with_arrow": {
+    "unicode": "1F4E9",
+    "unicode_alternates": [],
+    "name": "envelope with downwards arrow above",
+    "shortname": ":envelope_with_arrow:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["email"],
+    "moji": "📩"
+  },
+  "euro": {
+    "unicode": "1F4B6",
+    "unicode_alternates": [],
+    "name": "banknote with euro sign",
+    "shortname": ":euro:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["currency", "dollar", "money", "euro", "europe", "banknote", "money", "currency", "paper", "cash", "bills"],
+    "moji": "💶"
+  },
+  "european_castle": {
+    "unicode": "1F3F0",
+    "unicode_alternates": [],
+    "name": "european castle",
+    "shortname": ":european_castle:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["building", "history", "royalty", "castle", "european", "residence", "royalty", "disneyland", "disney", "fort", "fortified", "moat", "tower", "princess", "prince", "lord", "king", "queen", "fortress", "nobel", "stronghold"],
+    "moji": "🏰"
+  },
+  "european_post_office": {
+    "unicode": "1F3E4",
+    "unicode_alternates": [],
+    "name": "european post office",
+    "shortname": ":european_post_office:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["building"],
+    "moji": "🏤"
+  },
+  "evergreen_tree": {
+    "unicode": "1F332",
+    "unicode_alternates": [],
+    "name": "evergreen tree",
+    "shortname": ":evergreen_tree:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["nature", "plant", "evergreen", "tree", "needles", "christmas"],
+    "moji": "🌲"
+  },
+  "exclamation": {
+    "unicode": "2757",
+    "unicode_alternates": ["2757-FE0F"],
+    "name": "heavy exclamation mark symbol",
+    "shortname": ":exclamation:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["surprise"],
+    "moji": "❗"
+  },
+  "expressionless": {
+    "unicode": "1F611",
+    "unicode_alternates": [],
+    "name": "expressionless face",
+    "shortname": ":expressionless:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": ["-_-", "-__-", "-___-"],
+    "keywords": ["expressionless", "blank", "void", "vapid", "without expression", "face", "indifferent"],
+    "moji": "😑"
+  },
+  "eye": {
+    "unicode": "1F441",
+    "unicode_alternates": [],
+    "name": "eye",
+    "shortname": ":eye:",
+    "category": "people",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["look", "peek", "watch"]
+  },
+  "eyeglasses": {
+    "unicode": "1F453",
+    "unicode_alternates": [],
+    "name": "eyeglasses",
+    "shortname": ":eyeglasses:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["accessories", "eyesight", "fashion", "eyeglasses", "spectacles", "eye", "sight", "nearsightedness", "myopia", "farsightedness", "hyperopia", "frames", "vision", "see", "blurry", "contacts"],
+    "moji": "👓"
+  },
+  "eyes": {
+    "unicode": "1F440",
+    "unicode_alternates": [],
+    "name": "eyes",
+    "shortname": ":eyes:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["look", "peek", "stalk", "watch"],
+    "moji": "👀"
+  },
+  "factory": {
+    "unicode": "1F3ED",
+    "unicode_alternates": [],
+    "name": "factory",
+    "shortname": ":factory:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["building"],
+    "moji": "🏭"
+  },
+  "fallen_leaf": {
+    "unicode": "1F342",
+    "unicode_alternates": [],
+    "name": "fallen leaf",
+    "shortname": ":fallen_leaf:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["leaves", "nature", "plant", "vegetable", "leaf", "fall", "color", "deciduous", "autumn"],
+    "moji": "🍂"
+  },
+  "family": {
+    "unicode": "1F46A",
+    "unicode_alternates": [],
+    "name": "family",
+    "shortname": ":family:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["child", "dad", "father", "home", "mom", "mother", "parents", "family", "mother", "father", "child", "girl", "boy", "group", "unit"],
+    "moji": "👪"
+  },
+  "family_mmb": {
+    "unicode": "1F468-1F468-1F466",
+    "unicode_alternates": ["1F468-200D-1F468-200D-1F466"],
+    "name": "family (man,man,boy)",
+    "shortname": ":family_mmb:",
+    "category": "people",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["child", "dad", "father", "parents", "group", "unit", "gay", "homosexual", "man", "boy"]
+  },
+  "family_mmbb": {
+    "unicode": "1F468-1F468-1F466-1F466",
+    "unicode_alternates": ["1F468-200D-1F468-200D-1F466-200D-1F466"],
+    "name": "family (man,man,boy,boy)",
+    "shortname": ":family_mmbb:",
+    "category": "people",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["children", "dad", "father", "parents", "group", "unit", "gay", "homosexual", "man", "boy"]
+  },
+  "family_mmg": {
+    "unicode": "1F468-1F468-1F467",
+    "unicode_alternates": ["1F468-200D-1F468-200D-1F467"],
+    "name": "family (man,man,girl)",
+    "shortname": ":family_mmg:",
+    "category": "people",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["child", "dad", "father", "parents", "group", "unit", "gay", "homosexual", "man", "girl"]
+  },
+  "family_mmgb": {
+    "unicode": "1F468-1F468-1F467-1F466",
+    "unicode_alternates": ["1F468-200D-1F468-200D-1F467-200D-1F466"],
+    "name": "family (man,man,girl,boy)",
+    "shortname": ":family_mmgb:",
+    "category": "people",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["children", "dad", "father", "parents", "group", "unit", "gay", "homosexual", "man", "girl", "boy"]
+  },
+  "family_mmgg": {
+    "unicode": "1F468-1F468-1F467-1F467",
+    "unicode_alternates": ["1F468-200D-1F468-200D-1F467-200D-1F467"],
+    "name": "family (man,man,girl,girl)",
+    "shortname": ":family_mmgg:",
+    "category": "people",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["children", "dad", "father", "parents", "group", "unit", "gay", "homosexual", "man", "girl"]
+  },
+  "family_mwbb": {
+    "unicode": "1F468-1F469-1F466-1F466",
+    "unicode_alternates": ["1F468-200D-1F469-200D-1F466-200D-1F466"],
+    "name": "family (man,woman,boy,boy)",
+    "shortname": ":family_mwbb:",
+    "category": "people",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["dad", "father", "mom", "mother", "parents", "children", "boy", "group", "unit", "man", "woman"]
+  },
+  "family_mwg": {
+    "unicode": "1F468-1F469-1F467",
+    "unicode_alternates": ["1F468-200D-1F469-200D-1F467"],
+    "name": "family (man,woman,girl)",
+    "shortname": ":family_mwg:",
+    "category": "people",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["child", "dad", "father", "mom", "mother", "parents", "girl", "boy", "group", "unit", "man", "woman"]
+  },
+  "family_mwgb": {
+    "unicode": "1F468-1F469-1F467-1F466",
+    "unicode_alternates": ["1F468-200D-1F469-200D-1F467-200D-1F466"],
+    "name": "family (man,woman,girl,boy)",
+    "shortname": ":family_mwgb:",
+    "category": "people",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["dad", "father", "mom", "mother", "parents", "children", "girl", "boy", "group", "unit", "man", "woman"]
+  },
+  "family_mwgg": {
+    "unicode": "1F468-1F469-1F467-1F467",
+    "unicode_alternates": ["1F468-200D-1F469-200D-1F467-200D-1F467"],
+    "name": "family (man,woman,girl,girl)",
+    "shortname": ":family_mwgg:",
+    "category": "people",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["dad", "father", "mom", "mother", "parents", "children", "girl", "group", "unit", "man", "woman"]
+  },
+  "family_wwb": {
+    "unicode": "1F469-1F469-1F466",
+    "unicode_alternates": ["1F469-200D-1F469-200D-1F466"],
+    "name": "family (woman,woman,boy)",
+    "shortname": ":family_wwb:",
+    "category": "people",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["mom", "mother", "parents", "child", "boy", "group", "unit", "gay", "lesbian", "homosexual", "woman"]
+  },
+  "family_wwbb": {
+    "unicode": "1F469-1F469-1F466-1F466",
+    "unicode_alternates": ["1F469-200D-1F469-200D-1F466-200D-1F466"],
+    "name": "family (woman,woman,boy,boy)",
+    "shortname": ":family_wwbb:",
+    "category": "people",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["mom", "mother", "parents", "children", "group", "unit", "gay", "lesbian", "homosexual", "woman", "boy"]
+  },
+  "family_wwg": {
+    "unicode": "1F469-1F469-1F467",
+    "unicode_alternates": ["1F469-200D-1F469-200D-1F467"],
+    "name": "family (woman,woman,girl)",
+    "shortname": ":family_wwg:",
+    "category": "people",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["mom", "mother", "parents", "child", "woman", "girl", "group", "unit", "gay", "lesbian", "homosexual"]
+  },
+  "family_wwgb": {
+    "unicode": "1F469-1F469-1F467-1F466",
+    "unicode_alternates": ["1F469-200D-1F469-200D-1F467-200D-1F466"],
+    "name": "family (woman,woman,girl,boy)",
+    "shortname": ":family_wwgb:",
+    "category": "people",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["mom", "mother", "parents", "children", "group", "unit", "gay", "lesbian", "homosexual", "woman", "girl", "boy"]
+  },
+  "family_wwgg": {
+    "unicode": "1F469-1F469-1F467-1F467",
+    "unicode_alternates": ["1F469-200D-1F469-200D-1F467-200D-1F467"],
+    "name": "family (woman,woman,girl,girl)",
+    "shortname": ":family_wwgg:",
+    "category": "people",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["mom", "mother", "parents", "children", "group", "unit", "gay", "lesbian", "homosexual", "woman", "girl"]
+  },
+  "fast_forward": {
+    "unicode": "23E9",
+    "unicode_alternates": [],
+    "name": "black right-pointing double triangle",
+    "shortname": ":fast_forward:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blue-square"],
+    "moji": "⏩"
+  },
+  "fax": {
+    "unicode": "1F4E0",
+    "unicode_alternates": [],
+    "name": "fax machine",
+    "shortname": ":fax:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["communication", "technology"],
+    "moji": "📠"
+  },
+  "fearful": {
+    "unicode": "1F628",
+    "unicode_alternates": [],
+    "name": "fearful face",
+    "shortname": ":fearful:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["face", "nervous", "oops", "scared", "terrified", "fear", "fearful", "scared", "frightened"],
+    "moji": "😨"
+  },
+  "feet": {
+    "unicode": "1F43E",
+    "unicode_alternates": [],
+    "name": "paw prints",
+    "shortname": ":feet:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "cat", "dog", "footprints", "paw", "pet", "tracking", "paw", "prints", "mark", "imprints", "footsteps", "animal", "lion", "bear", "dog", "cat", "raccoon", "critter", "feet", "pawsteps"],
+    "moji": "🐾"
+  },
+  "ferris_wheel": {
+    "unicode": "1F3A1",
+    "unicode_alternates": [],
+    "name": "ferris wheel",
+    "shortname": ":ferris_wheel:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["carnival", "londoneye", "photo", "farris", "wheel", "amusement", "park", "fair", "ride", "entertainment"],
+    "moji": "🎡"
+  },
+  "file_cabinet": {
+    "unicode": "1F5C4",
+    "unicode_alternates": [],
+    "name": "file cabinet",
+    "shortname": ":file_cabinet:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["folders", "office", "documents", "storage"]
+  },
+  "file_folder": {
+    "unicode": "1F4C1",
+    "unicode_alternates": [],
+    "name": "file folder",
+    "shortname": ":file_folder:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["documents"],
+    "moji": "📁"
+  },
+  "film_frames": {
+    "unicode": "1F39E",
+    "unicode_alternates": [],
+    "name": "film frames",
+    "shortname": ":film_frames:",
+    "category": "activity",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["movie", "record", "8mm", "16mm", "reel", "celluloid"]
+  },
+  "finger_pointing_down": {
+    "unicode": "1F597",
+    "unicode_alternates": [],
+    "name": "white down pointing left hand index",
+    "shortname": ":finger_pointing_down:",
+    "category": "people",
+    "aliases": [":white_down_pointing_left_hand_index:"],
+    "aliases_ascii": [],
+    "keywords": ["direction", "finger", "hand"]
+  },
+  "finger_pointing_down2": {
+    "unicode": "1F59F",
+    "unicode_alternates": [],
+    "name": "sideways white down pointing index",
+    "shortname": ":finger_pointing_down2:",
+    "category": "people",
+    "aliases": [":sideways_white_down_pointing_index:"],
+    "aliases_ascii": [],
+    "keywords": ["direction", "finger", "hand"]
+  },
+  "finger_pointing_left": {
+    "unicode": "1F598",
+    "unicode_alternates": [],
+    "name": "sideways white left pointing index",
+    "shortname": ":finger_pointing_left:",
+    "category": "people",
+    "aliases": [":sideways_white_left_pointing_index:"],
+    "aliases_ascii": [],
+    "keywords": ["direction", "finger", "hand"]
+  },
+  "finger_pointing_right": {
+    "unicode": "1F599",
+    "unicode_alternates": [],
+    "name": "sideways white right pointing index",
+    "shortname": ":finger_pointing_right:",
+    "category": "people",
+    "aliases": [":sideways_white_right_pointing_index:"],
+    "aliases_ascii": [],
+    "keywords": ["direction", "finger", "hand"]
+  },
+  "finger_pointing_up": {
+    "unicode": "1F59E",
+    "unicode_alternates": [],
+    "name": "sideways white up pointing index",
+    "shortname": ":finger_pointing_up:",
+    "category": "people",
+    "aliases": [":sideways_white_up_pointing_index:"],
+    "aliases_ascii": [],
+    "keywords": ["direction", "finger", "hand"]
+  },
+  "fire": {
+    "unicode": "1F525",
+    "unicode_alternates": [],
+    "name": "fire",
+    "shortname": ":fire:",
+    "category": "emoticons",
+    "aliases": [":flame:"],
+    "aliases_ascii": [],
+    "keywords": ["cook", "hot", "flame"],
+    "moji": "🔥"
+  },
+  "fire_engine": {
+    "unicode": "1F692",
+    "unicode_alternates": [],
+    "name": "fire engine",
+    "shortname": ":fire_engine:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["cars", "transportation", "vehicle", "fire", "fighter", "engine", "truck", "emergency", "medical"],
+    "moji": "🚒"
+  },
+  "fire_engine_oncoming": {
+    "unicode": "1F6F1",
+    "unicode_alternates": [],
+    "name": "oncoming fire engine",
+    "shortname": ":fire_engine_oncoming:",
+    "category": "travel_places",
+    "aliases": [":oncoming_fire_engine:"],
+    "aliases_ascii": [],
+    "keywords": ["transportation", "vehicle", "fighter", "truck", "emergency"]
+  },
+  "fireworks": {
+    "unicode": "1F386",
+    "unicode_alternates": [],
+    "name": "fireworks",
+    "shortname": ":fireworks:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["carnival", "congratulations", "festival", "photo", "fireworks", "independence", "celebration", "explosion", "july", "4th", "rocket", "sky", "idea", "excitement"],
+    "moji": "🎆"
+  },
+  "first_quarter_moon": {
+    "unicode": "1F313",
+    "unicode_alternates": [],
+    "name": "first quarter moon symbol",
+    "shortname": ":first_quarter_moon:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["nature", "moon", "quarter", "first", "sky", "night", "cheese", "phase"],
+    "moji": "🌓"
+  },
+  "first_quarter_moon_with_face": {
+    "unicode": "1F31B",
+    "unicode_alternates": [],
+    "name": "first quarter moon with face",
+    "shortname": ":first_quarter_moon_with_face:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["nature", "moon", "first", "quarter", "anthropomorphic", "face", "sky", "night", "cheese", "phase"],
+    "moji": "🌛"
+  },
+  "fish": {
+    "unicode": "1F41F",
+    "unicode_alternates": [],
+    "name": "fish",
+    "shortname": ":fish:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "food", "nature"],
+    "moji": "🐟"
+  },
+  "fish_cake": {
+    "unicode": "1F365",
+    "unicode_alternates": [],
+    "name": "fish cake with swirl design",
+    "shortname": ":fish_cake:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["food", "fish", "cake", "kamboko", "swirl", "ramen", "noodles", "naruto"],
+    "moji": "🍥"
+  },
+  "fishing_pole_and_fish": {
+    "unicode": "1F3A3",
+    "unicode_alternates": [],
+    "name": "fishing pole and fish",
+    "shortname": ":fishing_pole_and_fish:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["food", "hobby", "fish", "fishing", "pole"],
+    "moji": "🎣"
+  },
+  "fist": {
+    "unicode": "270A",
+    "unicode_alternates": [],
+    "name": "raised fist",
+    "shortname": ":fist:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["fingers", "grasp", "hand"],
+    "moji": "✊"
+  },
+  "five": {
+    "moji": "5️⃣",
+    "unicode": "0035-20E3",
+    "unicode_alternates": ["0035-FE0F-20E3"],
+    "name": "digit five",
+    "shortname": ":five:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blue-square", "numbers", "prime"]
+  },
+  "flag_ac": {
+    "unicode": "1F1E6-1F1E8",
+    "unicode_alternates": [],
+    "name": "ascension",
+    "shortname": ":flag_ac:",
+    "category": "flags",
+    "aliases": [":ac:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "ac"]
+  },
+  "flag_ad": {
+    "unicode": "1F1E6-1F1E9",
+    "unicode_alternates": [],
+    "name": "andorra",
+    "shortname": ":flag_ad:",
+    "category": "flags",
+    "aliases": [":ad:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "ad"]
+  },
+  "flag_ae": {
+    "unicode": "1F1E6-1F1EA",
+    "unicode_alternates": [],
+    "name": "the united arab emirates",
+    "shortname": ":flag_ae:",
+    "category": "flags",
+    "aliases": [":ae:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "ae"]
+  },
+  "flag_af": {
+    "unicode": "1F1E6-1F1EB",
+    "unicode_alternates": [],
+    "name": "afghanistan",
+    "shortname": ":flag_af:",
+    "category": "flags",
+    "aliases": [":af:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "afghanestan", "af"]
+  },
+  "flag_ag": {
+    "unicode": "1F1E6-1F1EC",
+    "unicode_alternates": [],
+    "name": "antigua and barbuda",
+    "shortname": ":flag_ag:",
+    "category": "flags",
+    "aliases": [":ag:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "ag"]
+  },
+  "flag_ai": {
+    "unicode": "1F1E6-1F1EE",
+    "unicode_alternates": [],
+    "name": "anguilla",
+    "shortname": ":flag_ai:",
+    "category": "flags",
+    "aliases": [":ai:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "ai"]
+  },
+  "flag_al": {
+    "unicode": "1F1E6-1F1F1",
+    "unicode_alternates": [],
+    "name": "albania",
+    "shortname": ":flag_al:",
+    "category": "flags",
+    "aliases": [":al:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "shqiperia", "al"]
+  },
+  "flag_am": {
+    "unicode": "1F1E6-1F1F2",
+    "unicode_alternates": [],
+    "name": "armenia",
+    "shortname": ":flag_am:",
+    "category": "flags",
+    "aliases": [":am:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "hayastan", "am"]
+  },
+  "flag_ao": {
+    "unicode": "1F1E6-1F1F4",
+    "unicode_alternates": [],
+    "name": "angola",
+    "shortname": ":flag_ao:",
+    "category": "flags",
+    "aliases": [":ao:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "ao"]
+  },
+  "flag_ar": {
+    "unicode": "1F1E6-1F1F7",
+    "unicode_alternates": [],
+    "name": "argentina",
+    "shortname": ":flag_ar:",
+    "category": "flags",
+    "aliases": [":ar:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "ar"]
+  },
+  "flag_at": {
+    "unicode": "1F1E6-1F1F9",
+    "unicode_alternates": [],
+    "name": "austria",
+    "shortname": ":flag_at:",
+    "category": "flags",
+    "aliases": [":at:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "&ouml;sterreich", "osterreich", "at"]
+  },
+  "flag_au": {
+    "unicode": "1F1E6-1F1FA",
+    "unicode_alternates": [],
+    "name": "australia",
+    "shortname": ":flag_au:",
+    "category": "flags",
+    "aliases": [":au:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "au"]
+  },
+  "flag_aw": {
+    "unicode": "1F1E6-1F1FC",
+    "unicode_alternates": [],
+    "name": "aruba",
+    "shortname": ":flag_aw:",
+    "category": "flags",
+    "aliases": [":aw:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "aw"]
+  },
+  "flag_az": {
+    "unicode": "1F1E6-1F1FF",
+    "unicode_alternates": [],
+    "name": "azerbaijan",
+    "shortname": ":flag_az:",
+    "category": "flags",
+    "aliases": [":az:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "azarbaycan", "az"]
+  },
+  "flag_ba": {
+    "unicode": "1F1E7-1F1E6",
+    "unicode_alternates": [],
+    "name": "bosnia and herzegovina",
+    "shortname": ":flag_ba:",
+    "category": "flags",
+    "aliases": [":ba:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "bosna i hercegovina", "ba"]
+  },
+  "flag_bb": {
+    "unicode": "1F1E7-1F1E7",
+    "unicode_alternates": [],
+    "name": "barbados",
+    "shortname": ":flag_bb:",
+    "category": "flags",
+    "aliases": [":bb:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "bb"]
+  },
+  "flag_bd": {
+    "unicode": "1F1E7-1F1E9",
+    "unicode_alternates": [],
+    "name": "bangladesh",
+    "shortname": ":flag_bd:",
+    "category": "flags",
+    "aliases": [":bd:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "bd"]
+  },
+  "flag_be": {
+    "unicode": "1F1E7-1F1EA",
+    "unicode_alternates": [],
+    "name": "belgium",
+    "shortname": ":flag_be:",
+    "category": "flags",
+    "aliases": [":be:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "belgique", "belgie", "be"]
+  },
+  "flag_bf": {
+    "unicode": "1F1E7-1F1EB",
+    "unicode_alternates": [],
+    "name": "burkina faso",
+    "shortname": ":flag_bf:",
+    "category": "flags",
+    "aliases": [":bf:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "bf"]
+  },
+  "flag_bg": {
+    "unicode": "1F1E7-1F1EC",
+    "unicode_alternates": [],
+    "name": "bulgaria",
+    "shortname": ":flag_bg:",
+    "category": "flags",
+    "aliases": [":bg:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "bg"]
+  },
+  "flag_bh": {
+    "unicode": "1F1E7-1F1ED",
+    "unicode_alternates": [],
+    "name": "bahrain",
+    "shortname": ":flag_bh:",
+    "category": "flags",
+    "aliases": [":bh:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "al bahrayn", "bh"]
+  },
+  "flag_bi": {
+    "unicode": "1F1E7-1F1EE",
+    "unicode_alternates": [],
+    "name": "burundi",
+    "shortname": ":flag_bi:",
+    "category": "flags",
+    "aliases": [":bi:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "bi"]
+  },
+  "flag_bj": {
+    "unicode": "1F1E7-1F1EF",
+    "unicode_alternates": [],
+    "name": "benin",
+    "shortname": ":flag_bj:",
+    "category": "flags",
+    "aliases": [":bj:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "bj"]
+  },
+  "flag_black": {
+    "unicode": "1F3F4",
+    "unicode_alternates": [],
+    "name": "waving black flag",
+    "shortname": ":flag_black:",
+    "category": "objects_symbols",
+    "aliases": [":waving_black_flag:"],
+    "aliases_ascii": [],
+    "keywords": ["symbol", "signal"]
+  },
+  "flag_bm": {
+    "unicode": "1F1E7-1F1F2",
+    "unicode_alternates": [],
+    "name": "bermuda",
+    "shortname": ":flag_bm:",
+    "category": "flags",
+    "aliases": [":bm:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "bm"]
+  },
+  "flag_bn": {
+    "unicode": "1F1E7-1F1F3",
+    "unicode_alternates": [],
+    "name": "brunei",
+    "shortname": ":flag_bn:",
+    "category": "flags",
+    "aliases": [":bn:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "bn"]
+  },
+  "flag_bo": {
+    "unicode": "1F1E7-1F1F4",
+    "unicode_alternates": [],
+    "name": "bolivia",
+    "shortname": ":flag_bo:",
+    "category": "flags",
+    "aliases": [":bo:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "bo"]
+  },
+  "flag_br": {
+    "unicode": "1F1E7-1F1F7",
+    "unicode_alternates": [],
+    "name": "brazil",
+    "shortname": ":flag_br:",
+    "category": "flags",
+    "aliases": [":br:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "brasil", "br"]
+  },
+  "flag_bs": {
+    "unicode": "1F1E7-1F1F8",
+    "unicode_alternates": [],
+    "name": "the bahamas",
+    "shortname": ":flag_bs:",
+    "category": "flags",
+    "aliases": [":bs:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "bs"]
+  },
+  "flag_bt": {
+    "unicode": "1F1E7-1F1F9",
+    "unicode_alternates": [],
+    "name": "bhutan",
+    "shortname": ":flag_bt:",
+    "category": "flags",
+    "aliases": [":bt:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "bt"]
+  },
+  "flag_bw": {
+    "unicode": "1F1E7-1F1FC",
+    "unicode_alternates": [],
+    "name": "botswana",
+    "shortname": ":flag_bw:",
+    "category": "flags",
+    "aliases": [":bw:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "bw"]
+  },
+  "flag_by": {
+    "unicode": "1F1E7-1F1FE",
+    "unicode_alternates": [],
+    "name": "belarus",
+    "shortname": ":flag_by:",
+    "category": "flags",
+    "aliases": [":by:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "byelarus", "by"]
+  },
+  "flag_bz": {
+    "unicode": "1F1E7-1F1FF",
+    "unicode_alternates": [],
+    "name": "belize",
+    "shortname": ":flag_bz:",
+    "category": "flags",
+    "aliases": [":bz:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "bz"]
+  },
+  "flag_ca": {
+    "unicode": "1F1E8-1F1E6",
+    "unicode_alternates": [],
+    "name": "canada",
+    "shortname": ":flag_ca:",
+    "category": "flags",
+    "aliases": [":ca:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "ca"]
+  },
+  "flag_cd": {
+    "unicode": "1F1E8-1F1E9",
+    "unicode_alternates": [],
+    "name": "the democratic republic of the congo",
+    "shortname": ":flag_cd:",
+    "category": "flags",
+    "aliases": [":congo:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "r&eacute;publique d&eacute;mocratique du congo", "republique democratique du congo", "cd"]
+  },
+  "flag_cf": {
+    "unicode": "1F1E8-1F1EB",
+    "unicode_alternates": [],
+    "name": "central african republic",
+    "shortname": ":flag_cf:",
+    "category": "flags",
+    "aliases": [":cf:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "cf"]
+  },
+  "flag_cg": {
+    "unicode": "1F1E8-1F1EC",
+    "unicode_alternates": [],
+    "name": "the republic of the congo",
+    "shortname": ":flag_cg:",
+    "category": "flags",
+    "aliases": [":cg:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "cg"]
+  },
+  "flag_ch": {
+    "unicode": "1F1E8-1F1ED",
+    "unicode_alternates": [],
+    "name": "switzerland",
+    "shortname": ":flag_ch:",
+    "category": "flags",
+    "aliases": [":ch:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "swiss"]
+  },
+  "flag_ci": {
+    "unicode": "1F1E8-1F1EE",
+    "unicode_alternates": [],
+    "name": "cote d'ivoire",
+    "shortname": ":flag_ci:",
+    "category": "flags",
+    "aliases": [":ci:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "ci"]
+  },
+  "flag_cl": {
+    "unicode": "1F1E8-1F1F1",
+    "unicode_alternates": [],
+    "name": "chile",
+    "shortname": ":flag_cl:",
+    "category": "flags",
+    "aliases": [":chile:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "cl"]
+  },
+  "flag_cm": {
+    "unicode": "1F1E8-1F1F2",
+    "unicode_alternates": [],
+    "name": "cameroon",
+    "shortname": ":flag_cm:",
+    "category": "flags",
+    "aliases": [":cm:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "cm"]
+  },
+  "flag_cn": {
+    "unicode": "1F1E8-1F1F3",
+    "unicode_alternates": [],
+    "name": "china",
+    "shortname": ":flag_cn:",
+    "category": "flags",
+    "aliases": [":cn:"],
+    "aliases_ascii": [],
+    "keywords": ["chinese", "prc", "zhong guo", "country", "nation", "cn"]
+  },
+  "flag_co": {
+    "unicode": "1F1E8-1F1F4",
+    "unicode_alternates": [],
+    "name": "colombia",
+    "shortname": ":flag_co:",
+    "category": "flags",
+    "aliases": [":co:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "co"]
+  },
+  "flag_cr": {
+    "unicode": "1F1E8-1F1F7",
+    "unicode_alternates": [],
+    "name": "costa rica",
+    "shortname": ":flag_cr:",
+    "category": "flags",
+    "aliases": [":cr:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "cr"]
+  },
+  "flag_cu": {
+    "unicode": "1F1E8-1F1FA",
+    "unicode_alternates": [],
+    "name": "cuba",
+    "shortname": ":flag_cu:",
+    "category": "flags",
+    "aliases": [":cu:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "cu"]
+  },
+  "flag_cv": {
+    "unicode": "1F1E8-1F1FB",
+    "unicode_alternates": [],
+    "name": "cape verde",
+    "shortname": ":flag_cv:",
+    "category": "flags",
+    "aliases": [":cv:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "cabo verde", "cv"]
+  },
+  "flag_cy": {
+    "unicode": "1F1E8-1F1FE",
+    "unicode_alternates": [],
+    "name": "cyprus",
+    "shortname": ":flag_cy:",
+    "category": "flags",
+    "aliases": [":cy:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "kibris", "kypros", "cy"]
+  },
+  "flag_cz": {
+    "unicode": "1F1E8-1F1FF",
+    "unicode_alternates": [],
+    "name": "the czech republic",
+    "shortname": ":flag_cz:",
+    "category": "flags",
+    "aliases": [":cz:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "ceska republika", "cz"]
+  },
+  "flag_de": {
+    "unicode": "1F1E9-1F1EA",
+    "unicode_alternates": [],
+    "name": "germany",
+    "shortname": ":flag_de:",
+    "category": "flags",
+    "aliases": [":de:"],
+    "aliases_ascii": [],
+    "keywords": ["german", "nation", "deutschland", "country", "de"]
+  },
+  "flag_dj": {
+    "unicode": "1F1E9-1F1EF",
+    "unicode_alternates": [],
+    "name": "djibouti",
+    "shortname": ":flag_dj:",
+    "category": "flags",
+    "aliases": [":dj:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "dj"]
+  },
+  "flag_dk": {
+    "unicode": "1F1E9-1F1F0",
+    "unicode_alternates": [],
+    "name": "denmark",
+    "shortname": ":flag_dk:",
+    "category": "flags",
+    "aliases": [":dk:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "danmark", "dk"]
+  },
+  "flag_dm": {
+    "unicode": "1F1E9-1F1F2",
+    "unicode_alternates": [],
+    "name": "dominica",
+    "shortname": ":flag_dm:",
+    "category": "flags",
+    "aliases": [":dm:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "dm"]
+  },
+  "flag_do": {
+    "unicode": "1F1E9-1F1F4",
+    "unicode_alternates": [],
+    "name": "the dominican republic",
+    "shortname": ":flag_do:",
+    "category": "flags",
+    "aliases": [":do:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "do"]
+  },
+  "flag_dz": {
+    "unicode": "1F1E9-1F1FF",
+    "unicode_alternates": [],
+    "name": "algeria",
+    "shortname": ":flag_dz:",
+    "category": "flags",
+    "aliases": [":dz:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "al jaza'ir", "al jazair", "dz"]
+  },
+  "flag_ec": {
+    "unicode": "1F1EA-1F1E8",
+    "unicode_alternates": [],
+    "name": "ecuador",
+    "shortname": ":flag_ec:",
+    "category": "flags",
+    "aliases": [":ec:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "ec"]
+  },
+  "flag_ee": {
+    "unicode": "1F1EA-1F1EA",
+    "unicode_alternates": [],
+    "name": "estonia",
+    "shortname": ":flag_ee:",
+    "category": "flags",
+    "aliases": [":ee:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "eesti vabariik", "ee"]
+  },
+  "flag_eg": {
+    "unicode": "1F1EA-1F1EC",
+    "unicode_alternates": [],
+    "name": "egypt",
+    "shortname": ":flag_eg:",
+    "category": "flags",
+    "aliases": [":eg:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "misr", "eg"]
+  },
+  "flag_eh": {
+    "unicode": "1F1EA-1F1ED",
+    "unicode_alternates": [],
+    "name": "western sahara",
+    "shortname": ":flag_eh:",
+    "category": "flags",
+    "aliases": [":eh:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "aṣ-Ṣaḥrā’ al-gharbīyah", "sahra", "gharbiyah", "eh"]
+  },
+  "flag_er": {
+    "unicode": "1F1EA-1F1F7",
+    "unicode_alternates": [],
+    "name": "eritrea",
+    "shortname": ":flag_er:",
+    "category": "flags",
+    "aliases": [":er:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "hagere ertra", "er"]
+  },
+  "flag_es": {
+    "unicode": "1F1EA-1F1F8",
+    "unicode_alternates": [],
+    "name": "spain",
+    "shortname": ":flag_es:",
+    "category": "flags",
+    "aliases": [":es:"],
+    "aliases_ascii": [],
+    "keywords": ["nation", "espa&ntilde;a", "country", "espana", "es"]
+  },
+  "flag_et": {
+    "unicode": "1F1EA-1F1F9",
+    "unicode_alternates": [],
+    "name": "ethiopia",
+    "shortname": ":flag_et:",
+    "category": "flags",
+    "aliases": [":et:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "ityop'iya", "ityopiya", "et"]
+  },
+  "flag_fi": {
+    "unicode": "1F1EB-1F1EE",
+    "unicode_alternates": [],
+    "name": "finland",
+    "shortname": ":flag_fi:",
+    "category": "flags",
+    "aliases": [":fi:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "suomen tasavalta", "fi"]
+  },
+  "flag_fj": {
+    "unicode": "1F1EB-1F1EF",
+    "unicode_alternates": [],
+    "name": "fiji",
+    "shortname": ":flag_fj:",
+    "category": "flags",
+    "aliases": [":fj:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "fj"]
+  },
+  "flag_fk": {
+    "unicode": "1F1EB-1F1F0",
+    "unicode_alternates": [],
+    "name": "falkland islands",
+    "shortname": ":flag_fk:",
+    "category": "flags",
+    "aliases": [":fk:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "islas malvinas", "fk"]
+  },
+  "flag_fm": {
+    "unicode": "1F1EB-1F1F2",
+    "unicode_alternates": [],
+    "name": "micronesia",
+    "shortname": ":flag_fm:",
+    "category": "flags",
+    "aliases": [":fm:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "fm"]
+  },
+  "flag_fo": {
+    "unicode": "1F1EB-1F1F4",
+    "unicode_alternates": [],
+    "name": "faroe islands",
+    "shortname": ":flag_fo:",
+    "category": "flags",
+    "aliases": [":fo:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "foroyar", "fo"]
+  },
+  "flag_fr": {
+    "unicode": "1F1EB-1F1F7",
+    "unicode_alternates": [],
+    "name": "france",
+    "shortname": ":flag_fr:",
+    "category": "flags",
+    "aliases": [":fr:"],
+    "aliases_ascii": [],
+    "keywords": ["french", "nation", "country", "fr"]
+  },
+  "flag_ga": {
+    "unicode": "1F1EC-1F1E6",
+    "unicode_alternates": [],
+    "name": "gabon",
+    "shortname": ":flag_ga:",
+    "category": "flags",
+    "aliases": [":ga:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "ga"]
+  },
+  "flag_gb": {
+    "unicode": "1F1EC-1F1E7",
+    "unicode_alternates": [],
+    "name": "great britain",
+    "shortname": ":flag_gb:",
+    "category": "flags",
+    "aliases": [":gb:"],
+    "aliases_ascii": [],
+    "keywords": ["UK", "gb", "britsh", "nation", "united kingdom", "england", "country"]
+  },
+  "flag_gd": {
+    "unicode": "1F1EC-1F1E9",
+    "unicode_alternates": [],
+    "name": "grenada",
+    "shortname": ":flag_gd:",
+    "category": "flags",
+    "aliases": [":gd:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "gd"]
+  },
+  "flag_ge": {
+    "unicode": "1F1EC-1F1EA",
+    "unicode_alternates": [],
+    "name": "georgia",
+    "shortname": ":flag_ge:",
+    "category": "flags",
+    "aliases": [":ge:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "sak'art'velo", "sakartvelo", "ge"]
+  },
+  "flag_gh": {
+    "unicode": "1F1EC-1F1ED",
+    "unicode_alternates": [],
+    "name": "ghana",
+    "shortname": ":flag_gh:",
+    "category": "flags",
+    "aliases": [":gh:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "gh"]
+  },
+  "flag_gi": {
+    "unicode": "1F1EC-1F1EE",
+    "unicode_alternates": [],
+    "name": "gibraltar",
+    "shortname": ":flag_gi:",
+    "category": "flags",
+    "aliases": [":gi:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "gi"]
+  },
+  "flag_gl": {
+    "unicode": "1F1EC-1F1F1",
+    "unicode_alternates": [],
+    "name": "greenland",
+    "shortname": ":flag_gl:",
+    "category": "flags",
+    "aliases": [":gl:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "kalaallit nunaat", "gl"]
+  },
+  "flag_gm": {
+    "unicode": "1F1EC-1F1F2",
+    "unicode_alternates": [],
+    "name": "the gambia",
+    "shortname": ":flag_gm:",
+    "category": "flags",
+    "aliases": [":gm:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "gm"]
+  },
+  "flag_gn": {
+    "unicode": "1F1EC-1F1F3",
+    "unicode_alternates": [],
+    "name": "guinea",
+    "shortname": ":flag_gn:",
+    "category": "flags",
+    "aliases": [":gn:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "guinee", "gn"]
+  },
+  "flag_gq": {
+    "unicode": "1F1EC-1F1F6",
+    "unicode_alternates": [],
+    "name": "equatorial guinea",
+    "shortname": ":flag_gq:",
+    "category": "flags",
+    "aliases": [":gq:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "guinea ecuatorial", "gq"]
+  },
+  "flag_gr": {
+    "unicode": "1F1EC-1F1F7",
+    "unicode_alternates": [],
+    "name": "greece",
+    "shortname": ":flag_gr:",
+    "category": "flags",
+    "aliases": [":gr:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "ellas", "ellada", "gr"]
+  },
+  "flag_gt": {
+    "unicode": "1F1EC-1F1F9",
+    "unicode_alternates": [],
+    "name": "guatemala",
+    "shortname": ":flag_gt:",
+    "category": "flags",
+    "aliases": [":gt:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "gt"]
+  },
+  "flag_gu": {
+    "unicode": "1F1EC-1F1FA",
+    "unicode_alternates": [],
+    "name": "guam",
+    "shortname": ":flag_gu:",
+    "category": "flags",
+    "aliases": [":gu:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "gu"]
+  },
+  "flag_gw": {
+    "unicode": "1F1EC-1F1FC",
+    "unicode_alternates": [],
+    "name": "guinea-bissau",
+    "shortname": ":flag_gw:",
+    "category": "flags",
+    "aliases": [":gw:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "guine-bissau", "guine bissau", "gw"]
+  },
+  "flag_gy": {
+    "unicode": "1F1EC-1F1FE",
+    "unicode_alternates": [],
+    "name": "guyana",
+    "shortname": ":flag_gy:",
+    "category": "flags",
+    "aliases": [":gy:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "gy"]
+  },
+  "flag_hk": {
+    "unicode": "1F1ED-1F1F0",
+    "unicode_alternates": [],
+    "name": "hong kong",
+    "shortname": ":flag_hk:",
+    "category": "flags",
+    "aliases": [":hk:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "xianggang", "hk"]
+  },
+  "flag_hn": {
+    "unicode": "1F1ED-1F1F3",
+    "unicode_alternates": [],
+    "name": "honduras",
+    "shortname": ":flag_hn:",
+    "category": "flags",
+    "aliases": [":hn:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "hn"]
+  },
+  "flag_hr": {
+    "unicode": "1F1ED-1F1F7",
+    "unicode_alternates": [],
+    "name": "croatia",
+    "shortname": ":flag_hr:",
+    "category": "flags",
+    "aliases": [":hr:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "hrvatska", "hr"]
+  },
+  "flag_ht": {
+    "unicode": "1F1ED-1F1F9",
+    "unicode_alternates": [],
+    "name": "haiti",
+    "shortname": ":flag_ht:",
+    "category": "flags",
+    "aliases": [":ht:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "ht"]
+  },
+  "flag_hu": {
+    "unicode": "1F1ED-1F1FA",
+    "unicode_alternates": [],
+    "name": "hungary",
+    "shortname": ":flag_hu:",
+    "category": "flags",
+    "aliases": [":hu:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "magyarorszag", "hu"]
+  },
+  "flag_id": {
+    "unicode": "1F1EE-1F1E9",
+    "unicode_alternates": [],
+    "name": "indonesia",
+    "shortname": ":flag_id:",
+    "category": "flags",
+    "aliases": [":indonesia:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "id"]
+  },
+  "flag_ie": {
+    "unicode": "1F1EE-1F1EA",
+    "unicode_alternates": [],
+    "name": "ireland",
+    "shortname": ":flag_ie:",
+    "category": "flags",
+    "aliases": [":ie:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "&eacute;ire", "eire", "ie"]
+  },
+  "flag_il": {
+    "unicode": "1F1EE-1F1F1",
+    "unicode_alternates": [],
+    "name": "israel",
+    "shortname": ":flag_il:",
+    "category": "flags",
+    "aliases": [":il:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "yisra'el", "yisrael", "il"]
+  },
+  "flag_in": {
+    "unicode": "1F1EE-1F1F3",
+    "unicode_alternates": [],
+    "name": "india",
+    "shortname": ":flag_in:",
+    "category": "flags",
+    "aliases": [":in:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "bharat", "in"]
+  },
+  "flag_iq": {
+    "unicode": "1F1EE-1F1F6",
+    "unicode_alternates": [],
+    "name": "iraq",
+    "shortname": ":flag_iq:",
+    "category": "flags",
+    "aliases": [":iq:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "iq"]
+  },
+  "flag_ir": {
+    "unicode": "1F1EE-1F1F7",
+    "unicode_alternates": [],
+    "name": "iran",
+    "shortname": ":flag_ir:",
+    "category": "flags",
+    "aliases": [":ir:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "ir"]
+  },
+  "flag_is": {
+    "unicode": "1F1EE-1F1F8",
+    "unicode_alternates": [],
+    "name": "iceland",
+    "shortname": ":flag_is:",
+    "category": "flags",
+    "aliases": [":is:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "lyoveldio island", "is"]
+  },
+  "flag_it": {
+    "unicode": "1F1EE-1F1F9",
+    "unicode_alternates": [],
+    "name": "italy",
+    "shortname": ":flag_it:",
+    "category": "flags",
+    "aliases": [":it:"],
+    "aliases_ascii": [],
+    "keywords": ["italia", "country", "nation", "it"]
+  },
+  "flag_je": {
+    "unicode": "1F1EF-1F1EA",
+    "unicode_alternates": [],
+    "name": "jersey",
+    "shortname": ":flag_je:",
+    "category": "flags",
+    "aliases": [":je:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "je"]
+  },
+  "flag_jm": {
+    "unicode": "1F1EF-1F1F2",
+    "unicode_alternates": [],
+    "name": "jamaica",
+    "shortname": ":flag_jm:",
+    "category": "flags",
+    "aliases": [":jm:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "jm"]
+  },
+  "flag_jo": {
+    "unicode": "1F1EF-1F1F4",
+    "unicode_alternates": [],
+    "name": "jordan",
+    "shortname": ":flag_jo:",
+    "category": "flags",
+    "aliases": [":jo:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "al urdun", "jo"]
+  },
+  "flag_jp": {
+    "unicode": "1F1EF-1F1F5",
+    "unicode_alternates": [],
+    "name": "japan",
+    "shortname": ":flag_jp:",
+    "category": "flags",
+    "aliases": [":jp:"],
+    "aliases_ascii": [],
+    "keywords": ["nation", "nippon", "country", "jp"]
+  },
+  "flag_ke": {
+    "unicode": "1F1F0-1F1EA",
+    "unicode_alternates": [],
+    "name": "kenya",
+    "shortname": ":flag_ke:",
+    "category": "flags",
+    "aliases": [":ke:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "ke"]
+  },
+  "flag_kg": {
+    "unicode": "1F1F0-1F1EC",
+    "unicode_alternates": [],
+    "name": "kyrgyzstan",
+    "shortname": ":flag_kg:",
+    "category": "flags",
+    "aliases": [":kg:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "kyrgyz respublikasy", "kg"]
+  },
+  "flag_kh": {
+    "unicode": "1F1F0-1F1ED",
+    "unicode_alternates": [],
+    "name": "cambodia",
+    "shortname": ":flag_kh:",
+    "category": "flags",
+    "aliases": [":kh:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "kampuchea", "kh"]
+  },
+  "flag_ki": {
+    "unicode": "1F1F0-1F1EE",
+    "unicode_alternates": [],
+    "name": "kiribati",
+    "shortname": ":flag_ki:",
+    "category": "flags",
+    "aliases": [":ki:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "kiribati", "kiribas", "ki"]
+  },
+  "flag_km": {
+    "unicode": "1F1F0-1F1F2",
+    "unicode_alternates": [],
+    "name": "the comoros",
+    "shortname": ":flag_km:",
+    "category": "flags",
+    "aliases": [":km:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "km"]
+  },
+  "flag_kn": {
+    "unicode": "1F1F0-1F1F3",
+    "unicode_alternates": [],
+    "name": "saint kitts and nevis",
+    "shortname": ":flag_kn:",
+    "category": "flags",
+    "aliases": [":kn:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "kn"]
+  },
+  "flag_kp": {
+    "unicode": "1F1F0-1F1F5",
+    "unicode_alternates": [],
+    "name": "north korea",
+    "shortname": ":flag_kp:",
+    "category": "flags",
+    "aliases": [":kp:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "kp"]
+  },
+  "flag_kr": {
+    "unicode": "1F1F0-1F1F7",
+    "unicode_alternates": [],
+    "name": "korea",
+    "shortname": ":flag_kr:",
+    "category": "flags",
+    "aliases": [":kr:"],
+    "aliases_ascii": [],
+    "keywords": ["nation", "country", "south korea", "kr"]
+  },
+  "flag_kw": {
+    "unicode": "1F1F0-1F1FC",
+    "unicode_alternates": [],
+    "name": "kuwait",
+    "shortname": ":flag_kw:",
+    "category": "flags",
+    "aliases": [":kw:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "al kuwayt", "kw"]
+  },
+  "flag_ky": {
+    "unicode": "1F1F0-1F1FE",
+    "unicode_alternates": [],
+    "name": "cayman islands",
+    "shortname": ":flag_ky:",
+    "category": "flags",
+    "aliases": [":ky:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "ky"]
+  },
+  "flag_kz": {
+    "unicode": "1F1F0-1F1FF",
+    "unicode_alternates": [],
+    "name": "kazakhstan",
+    "shortname": ":flag_kz:",
+    "category": "flags",
+    "aliases": [":kz:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "qazaqstan", "kz"]
+  },
+  "flag_la": {
+    "unicode": "1F1F1-1F1E6",
+    "unicode_alternates": [],
+    "name": "laos",
+    "shortname": ":flag_la:",
+    "category": "flags",
+    "aliases": [":la:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "la"]
+  },
+  "flag_lb": {
+    "unicode": "1F1F1-1F1E7",
+    "unicode_alternates": [],
+    "name": "lebanon",
+    "shortname": ":flag_lb:",
+    "category": "flags",
+    "aliases": [":lb:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "lubnan", "lb"]
+  },
+  "flag_lc": {
+    "unicode": "1F1F1-1F1E8",
+    "unicode_alternates": [],
+    "name": "saint lucia",
+    "shortname": ":flag_lc:",
+    "category": "flags",
+    "aliases": [":lc:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "lc"]
+  },
+  "flag_li": {
+    "unicode": "1F1F1-1F1EE",
+    "unicode_alternates": [],
+    "name": "liechtenstein",
+    "shortname": ":flag_li:",
+    "category": "flags",
+    "aliases": [":li:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "li"]
+  },
+  "flag_lk": {
+    "unicode": "1F1F1-1F1F0",
+    "unicode_alternates": [],
+    "name": "sri lanka",
+    "shortname": ":flag_lk:",
+    "category": "flags",
+    "aliases": [":lk:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "lk"]
+  },
+  "flag_lr": {
+    "unicode": "1F1F1-1F1F7",
+    "unicode_alternates": [],
+    "name": "liberia",
+    "shortname": ":flag_lr:",
+    "category": "flags",
+    "aliases": [":lr:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "lr"]
+  },
+  "flag_ls": {
+    "unicode": "1F1F1-1F1F8",
+    "unicode_alternates": [],
+    "name": "lesotho",
+    "shortname": ":flag_ls:",
+    "category": "flags",
+    "aliases": [":ls:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "ls"]
+  },
+  "flag_lt": {
+    "unicode": "1F1F1-1F1F9",
+    "unicode_alternates": [],
+    "name": "lithuania",
+    "shortname": ":flag_lt:",
+    "category": "flags",
+    "aliases": [":lt:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "lietuva", "lt"]
+  },
+  "flag_lu": {
+    "unicode": "1F1F1-1F1FA",
+    "unicode_alternates": [],
+    "name": "luxembourg",
+    "shortname": ":flag_lu:",
+    "category": "flags",
+    "aliases": [":lu:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "luxembourg", "letzebuerg", "lu"]
+  },
+  "flag_lv": {
+    "unicode": "1F1F1-1F1FB",
+    "unicode_alternates": [],
+    "name": "latvia",
+    "shortname": ":flag_lv:",
+    "category": "flags",
+    "aliases": [":lv:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "latvija", "lv"]
+  },
+  "flag_ly": {
+    "unicode": "1F1F1-1F1FE",
+    "unicode_alternates": [],
+    "name": "libya",
+    "shortname": ":flag_ly:",
+    "category": "flags",
+    "aliases": [":ly:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "libiyah", "ly"]
+  },
+  "flag_ma": {
+    "unicode": "1F1F2-1F1E6",
+    "unicode_alternates": [],
+    "name": "morocco",
+    "shortname": ":flag_ma:",
+    "category": "flags",
+    "aliases": [":ma:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "al maghrib", "ma"]
+  },
+  "flag_mc": {
+    "unicode": "1F1F2-1F1E8",
+    "unicode_alternates": [],
+    "name": "monaco",
+    "shortname": ":flag_mc:",
+    "category": "flags",
+    "aliases": [":mc:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "mc"]
+  },
+  "flag_md": {
+    "unicode": "1F1F2-1F1E9",
+    "unicode_alternates": [],
+    "name": "moldova",
+    "shortname": ":flag_md:",
+    "category": "flags",
+    "aliases": [":md:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "md"]
+  },
+  "flag_me": {
+    "unicode": "1F1F2-1F1EA",
+    "unicode_alternates": [],
+    "name": "montenegro",
+    "shortname": ":flag_me:",
+    "category": "flags",
+    "aliases": [":me:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "crna gora", "me"]
+  },
+  "flag_mg": {
+    "unicode": "1F1F2-1F1EC",
+    "unicode_alternates": [],
+    "name": "madagascar",
+    "shortname": ":flag_mg:",
+    "category": "flags",
+    "aliases": [":mg:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "mg"]
+  },
+  "flag_mh": {
+    "unicode": "1F1F2-1F1ED",
+    "unicode_alternates": [],
+    "name": "the marshall islands",
+    "shortname": ":flag_mh:",
+    "category": "flags",
+    "aliases": [":mh:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "mh"]
+  },
+  "flag_mk": {
+    "unicode": "1F1F2-1F1F0",
+    "unicode_alternates": [],
+    "name": "macedonia",
+    "shortname": ":flag_mk:",
+    "category": "flags",
+    "aliases": [":mk:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "mk"]
+  },
+  "flag_ml": {
+    "unicode": "1F1F2-1F1F1",
+    "unicode_alternates": [],
+    "name": "mali",
+    "shortname": ":flag_ml:",
+    "category": "flags",
+    "aliases": [":ml:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "ml"]
+  },
+  "flag_mm": {
+    "unicode": "1F1F2-1F1F2",
+    "unicode_alternates": [],
+    "name": "myanmar",
+    "shortname": ":flag_mm:",
+    "category": "flags",
+    "aliases": [":mm:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "myanma naingngandaw", "mm"]
+  },
+  "flag_mn": {
+    "unicode": "1F1F2-1F1F3",
+    "unicode_alternates": [],
+    "name": "mongolia",
+    "shortname": ":flag_mn:",
+    "category": "flags",
+    "aliases": [":mn:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "mongol uls", "mn"]
+  },
+  "flag_mo": {
+    "unicode": "1F1F2-1F1F4",
+    "unicode_alternates": [],
+    "name": "macau",
+    "shortname": ":flag_mo:",
+    "category": "flags",
+    "aliases": [":mo:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "aomen", "mo"]
+  },
+  "flag_mr": {
+    "unicode": "1F1F2-1F1F7",
+    "unicode_alternates": [],
+    "name": "mauritania",
+    "shortname": ":flag_mr:",
+    "category": "flags",
+    "aliases": [":mr:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "muritaniyah", "mr"]
+  },
+  "flag_ms": {
+    "unicode": "1F1F2-1F1F8",
+    "unicode_alternates": [],
+    "name": "montserrat",
+    "shortname": ":flag_ms:",
+    "category": "flags",
+    "aliases": [":ms:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "ms"]
+  },
+  "flag_mt": {
+    "unicode": "1F1F2-1F1F9",
+    "unicode_alternates": [],
+    "name": "malta",
+    "shortname": ":flag_mt:",
+    "category": "flags",
+    "aliases": [":mt:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "mt"]
+  },
+  "flag_mu": {
+    "unicode": "1F1F2-1F1FA",
+    "unicode_alternates": [],
+    "name": "mauritius",
+    "shortname": ":flag_mu:",
+    "category": "flags",
+    "aliases": [":mu:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "mu"]
+  },
+  "flag_mv": {
+    "unicode": "1F1F2-1F1FB",
+    "unicode_alternates": [],
+    "name": "maldives",
+    "shortname": ":flag_mv:",
+    "category": "flags",
+    "aliases": [":mv:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "dhivehi raajje", "mv"]
+  },
+  "flag_mw": {
+    "unicode": "1F1F2-1F1FC",
+    "unicode_alternates": [],
+    "name": "malawi",
+    "shortname": ":flag_mw:",
+    "category": "flags",
+    "aliases": [":mw:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "mw"]
+  },
+  "flag_mx": {
+    "unicode": "1F1F2-1F1FD",
+    "unicode_alternates": [],
+    "name": "mexico",
+    "shortname": ":flag_mx:",
+    "category": "flags",
+    "aliases": [":mx:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "mx"]
+  },
+  "flag_my": {
+    "unicode": "1F1F2-1F1FE",
+    "unicode_alternates": [],
+    "name": "malaysia",
+    "shortname": ":flag_my:",
+    "category": "flags",
+    "aliases": [":my:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "my"]
+  },
+  "flag_mz": {
+    "unicode": "1F1F2-1F1FF",
+    "unicode_alternates": [],
+    "name": "mozambique",
+    "shortname": ":flag_mz:",
+    "category": "flags",
+    "aliases": [":mz:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "mocambique", "mz"]
+  },
+  "flag_na": {
+    "unicode": "1F1F3-1F1E6",
+    "unicode_alternates": [],
+    "name": "namibia",
+    "shortname": ":flag_na:",
+    "category": "flags",
+    "aliases": [":na:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "na"]
+  },
+  "flag_nc": {
+    "unicode": "1F1F3-1F1E8",
+    "unicode_alternates": [],
+    "name": "new caledonia",
+    "shortname": ":flag_nc:",
+    "category": "flags",
+    "aliases": [":nc:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "nouvelle", "cal&eacute;donie", "caledonie", "nc"]
+  },
+  "flag_ne": {
+    "unicode": "1F1F3-1F1EA",
+    "unicode_alternates": [],
+    "name": "niger",
+    "shortname": ":flag_ne:",
+    "category": "flags",
+    "aliases": [":ne:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "ne"]
+  },
+  "flag_ng": {
+    "unicode": "1F1F3-1F1EC",
+    "unicode_alternates": [],
+    "name": "nigeria",
+    "shortname": ":flag_ng:",
+    "category": "flags",
+    "aliases": [":nigeria:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "ng"]
+  },
+  "flag_ni": {
+    "unicode": "1F1F3-1F1EE",
+    "unicode_alternates": [],
+    "name": "nicaragua",
+    "shortname": ":flag_ni:",
+    "category": "flags",
+    "aliases": [":ni:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "ni"]
+  },
+  "flag_nl": {
+    "unicode": "1F1F3-1F1F1",
+    "unicode_alternates": [],
+    "name": "the netherlands",
+    "shortname": ":flag_nl:",
+    "category": "flags",
+    "aliases": [":nl:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "nederland", "holland", "nl"]
+  },
+  "flag_no": {
+    "unicode": "1F1F3-1F1F4",
+    "unicode_alternates": [],
+    "name": "norway",
+    "shortname": ":flag_no:",
+    "category": "flags",
+    "aliases": [":no:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "norge", "no"]
+  },
+  "flag_np": {
+    "unicode": "1F1F3-1F1F5",
+    "unicode_alternates": [],
+    "name": "nepal",
+    "shortname": ":flag_np:",
+    "category": "flags",
+    "aliases": [":np:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "np"]
+  },
+  "flag_nr": {
+    "unicode": "1F1F3-1F1F7",
+    "unicode_alternates": [],
+    "name": "nauru",
+    "shortname": ":flag_nr:",
+    "category": "flags",
+    "aliases": [":nr:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "nr"]
+  },
+  "flag_nu": {
+    "unicode": "1F1F3-1F1FA",
+    "unicode_alternates": [],
+    "name": "niue",
+    "shortname": ":flag_nu:",
+    "category": "flags",
+    "aliases": [":nu:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "nu"]
+  },
+  "flag_nz": {
+    "unicode": "1F1F3-1F1FF",
+    "unicode_alternates": [],
+    "name": "new zealand",
+    "shortname": ":flag_nz:",
+    "category": "flags",
+    "aliases": [":nz:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "aotearoa", "nz"]
+  },
+  "flag_om": {
+    "unicode": "1F1F4-1F1F2",
+    "unicode_alternates": [],
+    "name": "oman",
+    "shortname": ":flag_om:",
+    "category": "flags",
+    "aliases": [":om:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "saltanat uman", "om"]
+  },
+  "flag_pa": {
+    "unicode": "1F1F5-1F1E6",
+    "unicode_alternates": [],
+    "name": "panama",
+    "shortname": ":flag_pa:",
+    "category": "flags",
+    "aliases": [":pa:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "pa"]
+  },
+  "flag_pe": {
+    "unicode": "1F1F5-1F1EA",
+    "unicode_alternates": [],
+    "name": "peru",
+    "shortname": ":flag_pe:",
+    "category": "flags",
+    "aliases": [":pe:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "pe"]
+  },
+  "flag_pf": {
+    "unicode": "1F1F5-1F1EB",
+    "unicode_alternates": [],
+    "name": "french polynesia",
+    "shortname": ":flag_pf:",
+    "category": "flags",
+    "aliases": [":pf:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "polyn&eacute;sie fran&ccedil;aise", "polynesie francaise", "pf"]
+  },
+  "flag_pg": {
+    "unicode": "1F1F5-1F1EC",
+    "unicode_alternates": [],
+    "name": "papua new guinea",
+    "shortname": ":flag_pg:",
+    "category": "flags",
+    "aliases": [":pg:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "papua niu gini", "pg"]
+  },
+  "flag_ph": {
+    "unicode": "1F1F5-1F1ED",
+    "unicode_alternates": [],
+    "name": "the philippines",
+    "shortname": ":flag_ph:",
+    "category": "flags",
+    "aliases": [":ph:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "pilipinas", "ph"]
+  },
+  "flag_pk": {
+    "unicode": "1F1F5-1F1F0",
+    "unicode_alternates": [],
+    "name": "pakistan",
+    "shortname": ":flag_pk:",
+    "category": "flags",
+    "aliases": [":pk:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "pk"]
+  },
+  "flag_pl": {
+    "unicode": "1F1F5-1F1F1",
+    "unicode_alternates": [],
+    "name": "poland",
+    "shortname": ":flag_pl:",
+    "category": "flags",
+    "aliases": [":pl:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "polska", "pl"]
+  },
+  "flag_pr": {
+    "unicode": "1F1F5-1F1F7",
+    "unicode_alternates": [],
+    "name": "puerto rico",
+    "shortname": ":flag_pr:",
+    "category": "flags",
+    "aliases": [":pr:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "pr"]
+  },
+  "flag_ps": {
+    "unicode": "1F1F5-1F1F8",
+    "unicode_alternates": [],
+    "name": "palestinian authority",
+    "shortname": ":flag_ps:",
+    "category": "flags",
+    "aliases": [":ps:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "ps"]
+  },
+  "flag_pt": {
+    "unicode": "1F1F5-1F1F9",
+    "unicode_alternates": [],
+    "name": "portugal",
+    "shortname": ":flag_pt:",
+    "category": "flags",
+    "aliases": [":pt:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "pt"]
+  },
+  "flag_pw": {
+    "unicode": "1F1F5-1F1FC",
+    "unicode_alternates": [],
+    "name": "palau",
+    "shortname": ":flag_pw:",
+    "category": "flags",
+    "aliases": [":pw:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "belau", "pw"]
+  },
+  "flag_py": {
+    "unicode": "1F1F5-1F1FE",
+    "unicode_alternates": [],
+    "name": "paraguay",
+    "shortname": ":flag_py:",
+    "category": "flags",
+    "aliases": [":py:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "py"]
+  },
+  "flag_qa": {
+    "unicode": "1F1F6-1F1E6",
+    "unicode_alternates": [],
+    "name": "qatar",
+    "shortname": ":flag_qa:",
+    "category": "flags",
+    "aliases": [":qa:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "dawlat qatar", "qa"]
+  },
+  "flag_ro": {
+    "unicode": "1F1F7-1F1F4",
+    "unicode_alternates": [],
+    "name": "romania",
+    "shortname": ":flag_ro:",
+    "category": "flags",
+    "aliases": [":ro:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "ro"]
+  },
+  "flag_rs": {
+    "unicode": "1F1F7-1F1F8",
+    "unicode_alternates": [],
+    "name": "serbia",
+    "shortname": ":flag_rs:",
+    "category": "flags",
+    "aliases": [":rs:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "srbija", "rs"]
+  },
+  "flag_ru": {
+    "unicode": "1F1F7-1F1FA",
+    "unicode_alternates": [],
+    "name": "russia",
+    "shortname": ":flag_ru:",
+    "category": "flags",
+    "aliases": [":ru:"],
+    "aliases_ascii": [],
+    "keywords": ["nation", "russian", "country", "ru"]
+  },
+  "flag_rw": {
+    "unicode": "1F1F7-1F1FC",
+    "unicode_alternates": [],
+    "name": "rwanda",
+    "shortname": ":flag_rw:",
+    "category": "flags",
+    "aliases": [":rw:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "rw"]
+  },
+  "flag_sa": {
+    "unicode": "1F1F8-1F1E6",
+    "unicode_alternates": [],
+    "name": "saudi arabia",
+    "shortname": ":flag_sa:",
+    "category": "flags",
+    "aliases": [":saudiarabia:", ":saudi:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "al arabiyah as suudiyah", "sa"]
+  },
+  "flag_sb": {
+    "unicode": "1F1F8-1F1E7",
+    "unicode_alternates": [],
+    "name": "the solomon islands",
+    "shortname": ":flag_sb:",
+    "category": "flags",
+    "aliases": [":sb:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "sb"]
+  },
+  "flag_sc": {
+    "unicode": "1F1F8-1F1E8",
+    "unicode_alternates": [],
+    "name": "the seychelles",
+    "shortname": ":flag_sc:",
+    "category": "flags",
+    "aliases": [":sc:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "seychelles", "sc"]
+  },
+  "flag_sd": {
+    "unicode": "1F1F8-1F1E9",
+    "unicode_alternates": [],
+    "name": "sudan",
+    "shortname": ":flag_sd:",
+    "category": "flags",
+    "aliases": [":sd:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "as-sudan", "sd"]
+  },
+  "flag_se": {
+    "unicode": "1F1F8-1F1EA",
+    "unicode_alternates": [],
+    "name": "sweden",
+    "shortname": ":flag_se:",
+    "category": "flags",
+    "aliases": [":se:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "sverige", "se"]
+  },
+  "flag_sg": {
+    "unicode": "1F1F8-1F1EC",
+    "unicode_alternates": [],
+    "name": "singapore",
+    "shortname": ":flag_sg:",
+    "category": "flags",
+    "aliases": [":sg:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "sg"]
+  },
+  "flag_sh": {
+    "unicode": "1F1F8-1F1ED",
+    "unicode_alternates": [],
+    "name": "saint helena",
+    "shortname": ":flag_sh:",
+    "category": "flags",
+    "aliases": [":sh:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "sh"]
+  },
+  "flag_si": {
+    "unicode": "1F1F8-1F1EE",
+    "unicode_alternates": [],
+    "name": "slovenia",
+    "shortname": ":flag_si:",
+    "category": "flags",
+    "aliases": [":si:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "slovenija", "si"]
+  },
+  "flag_sk": {
+    "unicode": "1F1F8-1F1F0",
+    "unicode_alternates": [],
+    "name": "slovakia",
+    "shortname": ":flag_sk:",
+    "category": "flags",
+    "aliases": [":sk:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "sk"]
+  },
+  "flag_sl": {
+    "unicode": "1F1F8-1F1F1",
+    "unicode_alternates": [],
+    "name": "sierra leone",
+    "shortname": ":flag_sl:",
+    "category": "flags",
+    "aliases": [":sl:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "sl"]
+  },
+  "flag_sm": {
+    "unicode": "1F1F8-1F1F2",
+    "unicode_alternates": [],
+    "name": "san marino",
+    "shortname": ":flag_sm:",
+    "category": "flags",
+    "aliases": [":sm:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "sm"]
+  },
+  "flag_sn": {
+    "unicode": "1F1F8-1F1F3",
+    "unicode_alternates": [],
+    "name": "senegal",
+    "shortname": ":flag_sn:",
+    "category": "flags",
+    "aliases": [":sn:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "sn"]
+  },
+  "flag_so": {
+    "unicode": "1F1F8-1F1F4",
+    "unicode_alternates": [],
+    "name": "somalia",
+    "shortname": ":flag_so:",
+    "category": "flags",
+    "aliases": [":so:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "so"]
+  },
+  "flag_sr": {
+    "unicode": "1F1F8-1F1F7",
+    "unicode_alternates": [],
+    "name": "suriname",
+    "shortname": ":flag_sr:",
+    "category": "flags",
+    "aliases": [":sr:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "sr"]
+  },
+  "flag_st": {
+    "unicode": "1F1F8-1F1F9",
+    "unicode_alternates": [],
+    "name": "sao tome and principe",
+    "shortname": ":flag_st:",
+    "category": "flags",
+    "aliases": [":st:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "sao tome e principe", "st"]
+  },
+  "flag_sv": {
+    "unicode": "1F1F8-1F1FB",
+    "unicode_alternates": [],
+    "name": "el salvador",
+    "shortname": ":flag_sv:",
+    "category": "flags",
+    "aliases": [":sv:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "sv"]
+  },
+  "flag_sy": {
+    "unicode": "1F1F8-1F1FE",
+    "unicode_alternates": [],
+    "name": "syria",
+    "shortname": ":flag_sy:",
+    "category": "flags",
+    "aliases": [":sy:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "sy"]
+  },
+  "flag_sz": {
+    "unicode": "1F1F8-1F1FF",
+    "unicode_alternates": [],
+    "name": "swaziland",
+    "shortname": ":flag_sz:",
+    "category": "flags",
+    "aliases": [":sz:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "sz"]
+  },
+  "flag_td": {
+    "unicode": "1F1F9-1F1E9",
+    "unicode_alternates": [],
+    "name": "chad",
+    "shortname": ":flag_td:",
+    "category": "flags",
+    "aliases": [":td:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "tchad", "td"]
+  },
+  "flag_tg": {
+    "unicode": "1F1F9-1F1EC",
+    "unicode_alternates": [],
+    "name": "togo",
+    "shortname": ":flag_tg:",
+    "category": "flags",
+    "aliases": [":tg:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "republique togolaise", "tg"]
+  },
+  "flag_th": {
+    "unicode": "1F1F9-1F1ED",
+    "unicode_alternates": [],
+    "name": "thailand",
+    "shortname": ":flag_th:",
+    "category": "flags",
+    "aliases": [":th:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "prathet thai", "th"]
+  },
+  "flag_tj": {
+    "unicode": "1F1F9-1F1EF",
+    "unicode_alternates": [],
+    "name": "tajikistan",
+    "shortname": ":flag_tj:",
+    "category": "flags",
+    "aliases": [":tj:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "jumhurii tojikiston", "tj"]
+  },
+  "flag_tl": {
+    "unicode": "1F1F9-1F1F1",
+    "unicode_alternates": [],
+    "name": "east timor",
+    "shortname": ":flag_tl:",
+    "category": "flags",
+    "aliases": [":tl:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "tl"]
+  },
+  "flag_tm": {
+    "unicode": "1F1F9-1F1F2",
+    "unicode_alternates": [],
+    "name": "turkmenistan",
+    "shortname": ":flag_tm:",
+    "category": "flags",
+    "aliases": [":turkmenistan:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "tm"]
+  },
+  "flag_tn": {
+    "unicode": "1F1F9-1F1F3",
+    "unicode_alternates": [],
+    "name": "tunisia",
+    "shortname": ":flag_tn:",
+    "category": "flags",
+    "aliases": [":tn:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "tunis", "tn"]
+  },
+  "flag_to": {
+    "unicode": "1F1F9-1F1F4",
+    "unicode_alternates": [],
+    "name": "tonga",
+    "shortname": ":flag_to:",
+    "category": "flags",
+    "aliases": [":to:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "to"]
+  },
+  "flag_tr": {
+    "unicode": "1F1F9-1F1F7",
+    "unicode_alternates": [],
+    "name": "turkey",
+    "shortname": ":flag_tr:",
+    "category": "flags",
+    "aliases": [":tr:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "turkiye"]
+  },
+  "flag_tt": {
+    "unicode": "1F1F9-1F1F9",
+    "unicode_alternates": [],
+    "name": "trinidad and tobago",
+    "shortname": ":flag_tt:",
+    "category": "flags",
+    "aliases": [":tt:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "tt"]
+  },
+  "flag_tv": {
+    "unicode": "1F1F9-1F1FB",
+    "unicode_alternates": [],
+    "name": "tuvalu",
+    "shortname": ":flag_tv:",
+    "category": "flags",
+    "aliases": [":tuvalu:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "tv"]
+  },
+  "flag_tw": {
+    "unicode": "1F1F9-1F1FC",
+    "unicode_alternates": [],
+    "name": "the republic of china",
+    "shortname": ":flag_tw:",
+    "category": "flags",
+    "aliases": [":tw:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "taiwan", "tw"]
+  },
+  "flag_tz": {
+    "unicode": "1F1F9-1F1FF",
+    "unicode_alternates": [],
+    "name": "tanzania",
+    "shortname": ":flag_tz:",
+    "category": "flags",
+    "aliases": [":tz:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "tz"]
+  },
+  "flag_ua": {
+    "unicode": "1F1FA-1F1E6",
+    "unicode_alternates": [],
+    "name": "ukraine",
+    "shortname": ":flag_ua:",
+    "category": "flags",
+    "aliases": [":ua:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "ukrayina", "ua"]
+  },
+  "flag_ug": {
+    "unicode": "1F1FA-1F1EC",
+    "unicode_alternates": [],
+    "name": "uganda",
+    "shortname": ":flag_ug:",
+    "category": "flags",
+    "aliases": [":ug:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "ug"]
+  },
+  "flag_us": {
+    "unicode": "1F1FA-1F1F8",
+    "unicode_alternates": [],
+    "name": "united states",
+    "shortname": ":flag_us:",
+    "category": "flags",
+    "aliases": [":us:"],
+    "aliases_ascii": [],
+    "keywords": ["american", "country", "nation", "usa", "united states of america", "america", "old glory", "us"]
+  },
+  "flag_uy": {
+    "unicode": "1F1FA-1F1FE",
+    "unicode_alternates": [],
+    "name": "uruguay",
+    "shortname": ":flag_uy:",
+    "category": "flags",
+    "aliases": [":uy:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "uy"]
+  },
+  "flag_uz": {
+    "unicode": "1F1FA-1F1FF",
+    "unicode_alternates": [],
+    "name": "uzbekistan",
+    "shortname": ":flag_uz:",
+    "category": "flags",
+    "aliases": [":uz:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "uzbekiston respublikasi", "uz"]
+  },
+  "flag_va": {
+    "unicode": "1F1FB-1F1E6",
+    "unicode_alternates": [],
+    "name": "the vatican city",
+    "shortname": ":flag_va:",
+    "category": "flags",
+    "aliases": [":va:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "va"]
+  },
+  "flag_vc": {
+    "unicode": "1F1FB-1F1E8",
+    "unicode_alternates": [],
+    "name": "saint vincent and the grenadines",
+    "shortname": ":flag_vc:",
+    "category": "flags",
+    "aliases": [":vc:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "vc"]
+  },
+  "flag_ve": {
+    "unicode": "1F1FB-1F1EA",
+    "unicode_alternates": [],
+    "name": "venezuela",
+    "shortname": ":flag_ve:",
+    "category": "flags",
+    "aliases": [":ve:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "ve"]
+  },
+  "flag_vi": {
+    "unicode": "1F1FB-1F1EE",
+    "unicode_alternates": [],
+    "name": "u.s. virgin islands",
+    "shortname": ":flag_vi:",
+    "category": "flags",
+    "aliases": [":vi:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "vi"]
+  },
+  "flag_vn": {
+    "unicode": "1F1FB-1F1F3",
+    "unicode_alternates": [],
+    "name": "vietnam",
+    "shortname": ":flag_vn:",
+    "category": "flags",
+    "aliases": [":vn:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "viet nam", "vn"]
+  },
+  "flag_vu": {
+    "unicode": "1F1FB-1F1FA",
+    "unicode_alternates": [],
+    "name": "vanuatu",
+    "shortname": ":flag_vu:",
+    "category": "flags",
+    "aliases": [":vu:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "vu"]
+  },
+  "flag_wf": {
+    "unicode": "1F1FC-1F1EB",
+    "unicode_alternates": [],
+    "name": "wallis and futuna",
+    "shortname": ":flag_wf:",
+    "category": "flags",
+    "aliases": [":wf:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "wf"]
+  },
+  "flag_white": {
+    "unicode": "1F3F3",
+    "unicode_alternates": [],
+    "name": "waving white flag",
+    "shortname": ":flag_white:",
+    "category": "objects_symbols",
+    "aliases": [":waving_white_flag:"],
+    "aliases_ascii": [],
+    "keywords": ["symbol", "signal"]
+  },
+  "flag_ws": {
+    "unicode": "1F1FC-1F1F8",
+    "unicode_alternates": [],
+    "name": "samoa",
+    "shortname": ":flag_ws:",
+    "category": "flags",
+    "aliases": [":ws:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "american samoa", "ws"]
+  },
+  "flag_xk": {
+    "unicode": "1F1FD-1F1F0",
+    "unicode_alternates": [],
+    "name": "kosovo",
+    "shortname": ":flag_xk:",
+    "category": "flags",
+    "aliases": [":xk:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "xk"]
+  },
+  "flag_ye": {
+    "unicode": "1F1FE-1F1EA",
+    "unicode_alternates": [],
+    "name": "yemen",
+    "shortname": ":flag_ye:",
+    "category": "flags",
+    "aliases": [":ye:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "al yaman", "ye"]
+  },
+  "flag_za": {
+    "unicode": "1F1FF-1F1E6",
+    "unicode_alternates": [],
+    "name": "south africa",
+    "shortname": ":flag_za:",
+    "category": "flags",
+    "aliases": [":za:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation"]
+  },
+  "flag_zm": {
+    "unicode": "1F1FF-1F1F2",
+    "unicode_alternates": [],
+    "name": "zambia",
+    "shortname": ":flag_zm:",
+    "category": "flags",
+    "aliases": [":zm:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "zm"]
+  },
+  "flag_zw": {
+    "unicode": "1F1FF-1F1FC",
+    "unicode_alternates": [],
+    "name": "zimbabwe",
+    "shortname": ":flag_zw:",
+    "category": "flags",
+    "aliases": [":zw:"],
+    "aliases_ascii": [],
+    "keywords": ["country", "nation", "zw"]
+  },
+  "flags": {
+    "unicode": "1F38F",
+    "unicode_alternates": [],
+    "name": "carp streamer",
+    "shortname": ":flags:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["banner", "carp", "fish", "japanese", "koinobori", "children", "kids", "boys", "celebration", "happiness", "carp", "streamers", "japanese", "holiday", "flags"],
+    "moji": "🎏"
+  },
+  "flashlight": {
+    "unicode": "1F526",
+    "unicode_alternates": [],
+    "name": "electric torch",
+    "shortname": ":flashlight:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["dark"],
+    "moji": "🔦"
+  },
+  "flip_phone": {
+    "unicode": "1F581",
+    "unicode_alternates": [],
+    "name": "clamshell mobile phone",
+    "shortname": ":flip_phone:",
+    "category": "objects_symbols",
+    "aliases": [":clamshell_mobile_phone:"],
+    "aliases_ascii": [],
+    "keywords": ["cellphone"]
+  },
+  "floppy_black": {
+    "unicode": "1F5AA",
+    "unicode_alternates": [],
+    "name": "black hard shell floppy disk",
+    "shortname": ":floppy_black:",
+    "category": "objects_symbols",
+    "aliases": [":black_hard_shell_floppy_disk:"],
+    "aliases_ascii": [],
+    "keywords": ["oldschool", "save", "technology", "storage", "information", "computer", "drive", "megabyte"]
+  },
+  "floppy_disk": {
+    "unicode": "1F4BE",
+    "unicode_alternates": [],
+    "name": "floppy disk",
+    "shortname": ":floppy_disk:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["oldschool", "save", "technology", "floppy", "disk", "storage", "information", "computer", "drive", "megabyte"],
+    "moji": "💾"
+  },
+  "floppy_white": {
+    "unicode": "1F5AB",
+    "unicode_alternates": [],
+    "name": "white hard shell floppy disk",
+    "shortname": ":floppy_white:",
+    "category": "objects_symbols",
+    "aliases": [":white_hard_shell_floppy_disk:"],
+    "aliases_ascii": [],
+    "keywords": ["oldschool", "save", "technology", "storage", "information", "computer", "drive", "megabyte"]
+  },
+  "flower_playing_cards": {
+    "unicode": "1F3B4",
+    "unicode_alternates": [],
+    "name": "flower playing cards",
+    "shortname": ":flower_playing_cards:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["playing", "card", "flower", "game", "august", "moon", "special"],
+    "moji": "🎴"
+  },
+  "flushed": {
+    "unicode": "1F633",
+    "unicode_alternates": [],
+    "name": "flushed face",
+    "shortname": ":flushed:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [":$", "=$"],
+    "keywords": ["blush", "face", "flattered", "flush", "blush", "red", "pink", "cheeks", "shy"],
+    "moji": "😳"
+  },
+  "fog": {
+    "unicode": "1F32B",
+    "unicode_alternates": [],
+    "name": "fog",
+    "shortname": ":fog:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["weather", "damp", "cloud", "hazy"]
+  },
+  "foggy": {
+    "unicode": "1F301",
+    "unicode_alternates": [],
+    "name": "foggy",
+    "shortname": ":foggy:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["mountain", "photo", "bridge", "weather", "fog", "foggy"],
+    "moji": "🌁"
+  },
+  "folder": {
+    "unicode": "1F5C0",
+    "unicode_alternates": [],
+    "name": "folder",
+    "shortname": ":folder:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["documents"]
+  },
+  "folder_open": {
+    "unicode": "1F5C1",
+    "unicode_alternates": [],
+    "name": "open folder",
+    "shortname": ":folder_open:",
+    "category": "objects_symbols",
+    "aliases": [":open_folder:"],
+    "aliases_ascii": [],
+    "keywords": ["documents", "load"]
+  },
+  "football": {
+    "unicode": "1F3C8",
+    "unicode_alternates": [],
+    "name": "american football",
+    "shortname": ":football:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["NFL", "balls", "sports", "football", "ball", "sport", "america", "american"],
+    "moji": "🏈"
+  },
+  "footprints": {
+    "unicode": "1F463",
+    "unicode_alternates": [],
+    "name": "footprints",
+    "shortname": ":footprints:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["feet"],
+    "moji": "👣"
+  },
+  "fork_and_knife": {
+    "unicode": "1F374",
+    "unicode_alternates": [],
+    "name": "fork and knife",
+    "shortname": ":fork_and_knife:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["cutlery", "kitchen", "fork", "knife", "restaurant", "meal", "food", "eat"],
+    "moji": "🍴"
+  },
+  "fork_knife_plate": {
+    "unicode": "1F37D",
+    "unicode_alternates": [],
+    "name": "fork and knife with plate",
+    "shortname": ":fork_knife_plate:",
+    "category": "travel_places",
+    "aliases": [":fork_and_knife_with_plate:"],
+    "aliases_ascii": [],
+    "keywords": ["meal", "food", "breakfast", "lunch", "dinner", "utensils", "setting"]
+  },
+  "fountain": {
+    "unicode": "26F2",
+    "unicode_alternates": ["26F2-FE0F"],
+    "name": "fountain",
+    "shortname": ":fountain:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["photo"],
+    "moji": "⛲"
+  },
+  "four": {
+    "moji": "4️⃣",
+    "unicode": "0034-20E3",
+    "unicode_alternates": ["0034-FE0F-20E3"],
+    "name": "digit four",
+    "shortname": ":four:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["4", "blue-square", "numbers"]
+  },
+  "four_leaf_clover": {
+    "unicode": "1F340",
+    "unicode_alternates": [],
+    "name": "four leaf clover",
+    "shortname": ":four_leaf_clover:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["lucky", "nature", "plant", "vegetable", "clover", "four", "leaf", "luck", "irish", "saint", "patrick", "green"],
+    "moji": "🍀"
+  },
+  "frame_photo": {
+    "unicode": "1F5BC",
+    "unicode_alternates": [],
+    "name": "frame with picture",
+    "shortname": ":frame_photo:",
+    "category": "objects_symbols",
+    "aliases": [":frame_with_picture:"],
+    "aliases_ascii": [],
+    "keywords": ["photo"]
+  },
+  "frame_tiles": {
+    "unicode": "1F5BD",
+    "unicode_alternates": [],
+    "name": "frame with tiles",
+    "shortname": ":frame_tiles:",
+    "category": "objects_symbols",
+    "aliases": [":frame_with_tiles:"],
+    "aliases_ascii": [],
+    "keywords": ["photo", "painting"]
+  },
+  "frame_x": {
+    "unicode": "1F5BE",
+    "unicode_alternates": [],
+    "name": "frame with an x",
+    "shortname": ":frame_x:",
+    "category": "objects_symbols",
+    "aliases": [":frame_with_an_x:"],
+    "aliases_ascii": [],
+    "keywords": ["photo", "painting"]
+  },
+  "free": {
+    "unicode": "1F193",
+    "unicode_alternates": [],
+    "name": "squared free",
+    "shortname": ":free:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blue-square", "words"],
+    "moji": "🆓"
+  },
+  "fried_shrimp": {
+    "unicode": "1F364",
+    "unicode_alternates": [],
+    "name": "fried shrimp",
+    "shortname": ":fried_shrimp:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "food", "shrimp", "fried", "seafood", "small", "fish"],
+    "moji": "🍤"
+  },
+  "fries": {
+    "unicode": "1F35F",
+    "unicode_alternates": [],
+    "name": "french fries",
+    "shortname": ":fries:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["chips", "food", "fries", "french", "potato", "fry", "russet", "idaho"],
+    "moji": "🍟"
+  },
+  "frog": {
+    "unicode": "1F438",
+    "unicode_alternates": [],
+    "name": "frog face",
+    "shortname": ":frog:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "nature"],
+    "moji": "🐸"
+  },
+  "frowning": {
+    "unicode": "1F626",
+    "unicode_alternates": [],
+    "name": "frowning face with open mouth",
+    "shortname": ":frowning:",
+    "category": "emoticons",
+    "aliases": [":anguished:"],
+    "aliases_ascii": [],
+    "keywords": ["aw", "face", "frown", "sad", "pout", "sulk", "glower"],
+    "moji": "😦"
+  },
+  "fuelpump": {
+    "unicode": "26FD",
+    "unicode_alternates": ["26FD-FE0F"],
+    "name": "fuel pump",
+    "shortname": ":fuelpump:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["gas station", "petroleum"],
+    "moji": "⛽"
+  },
+  "full_moon": {
+    "unicode": "1F315",
+    "unicode_alternates": [],
+    "name": "full moon symbol",
+    "shortname": ":full_moon:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["nature", "yellow", "moon", "full", "sky", "night", "cheese", "phase", "monster", "spooky", "werewolves", "twilight"],
+    "moji": "🌕"
+  },
+  "full_moon_with_face": {
+    "unicode": "1F31D",
+    "unicode_alternates": [],
+    "name": "full moon with face",
+    "shortname": ":full_moon_with_face:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["night", "moon", "full", "anthropomorphic", "face", "sky", "night", "cheese", "phase", "spooky", "werewolves", "monsters"],
+    "moji": "🌝"
+  },
+  "game_die": {
+    "unicode": "1F3B2",
+    "unicode_alternates": [],
+    "name": "game die",
+    "shortname": ":game_die:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["dice", "game", "die", "dice", "craps", "gamble", "play"],
+    "moji": "🎲"
+  },
+  "gem": {
+    "unicode": "1F48E",
+    "unicode_alternates": [],
+    "name": "gem stone",
+    "shortname": ":gem:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blue", "ruby"],
+    "moji": "💎"
+  },
+  "gemini": {
+    "unicode": "264A",
+    "unicode_alternates": ["264A-FE0F"],
+    "name": "gemini",
+    "shortname": ":gemini:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["gemini", "twins", "astrology", "greek", "constellation", "stars", "zodiac", "sign", "sign", "zodiac", "horoscope"],
+    "moji": "♊"
+  },
+  "ghost": {
+    "unicode": "1F47B",
+    "unicode_alternates": [],
+    "name": "ghost",
+    "shortname": ":ghost:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["halloween"],
+    "moji": "👻"
+  },
+  "gift": {
+    "unicode": "1F381",
+    "unicode_alternates": [],
+    "name": "wrapped present",
+    "shortname": ":gift:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["birthday", "christmas", "present", "xmas", "gift", "present", "wrap", "package", "birthday", "wedding"],
+    "moji": "🎁"
+  },
+  "gift_heart": {
+    "unicode": "1F49D",
+    "unicode_alternates": [],
+    "name": "heart with ribbon",
+    "shortname": ":gift_heart:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["love", "valentines"],
+    "moji": "💝"
+  },
+  "girl": {
+    "unicode": "1F467",
+    "unicode_alternates": [],
+    "name": "girl",
+    "shortname": ":girl:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["female", "woman"],
+    "moji": "👧"
+  },
+  "girls_symbol": {
+    "unicode": "1F6CA",
+    "unicode_alternates": [],
+    "name": "girls symbol",
+    "shortname": ":girls_symbol:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["female", "child"]
+  },
+  "globe_with_meridians": {
+    "unicode": "1F310",
+    "unicode_alternates": [],
+    "name": "globe with meridians",
+    "shortname": ":globe_with_meridians:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["earth", "international", "world", "earth", "meridian", "globe", "space", "planet", "home"],
+    "moji": "🌐"
+  },
+  "goat": {
+    "unicode": "1F410",
+    "unicode_alternates": [],
+    "name": "goat",
+    "shortname": ":goat:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "nature", "goat", "sheep", "kid", "billy", "livestock"],
+    "moji": "🐐"
+  },
+  "golf": {
+    "unicode": "26F3",
+    "unicode_alternates": ["26F3-FE0F"],
+    "name": "flag in hole",
+    "shortname": ":golf:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["business", "sports"],
+    "moji": "⛳"
+  },
+  "golfer": {
+    "unicode": "1F3CC",
+    "unicode_alternates": [],
+    "name": "golfer",
+    "shortname": ":golfer:",
+    "category": "activity",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["sport", "par", "birdie", "eagle", "mulligan"]
+  },
+  "grapes": {
+    "unicode": "1F347",
+    "unicode_alternates": [],
+    "name": "grapes",
+    "shortname": ":grapes:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["food", "fruit", "grapes", "wine", "vinegar", "fruit", "cluster", "vine"],
+    "moji": "🍇"
+  },
+  "green_apple": {
+    "unicode": "1F34F",
+    "unicode_alternates": [],
+    "name": "green apple",
+    "shortname": ":green_apple:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["fruit", "nature", "apple", "fruit", "green", "pie", "granny", "smith", "core"],
+    "moji": "🍏"
+  },
+  "green_book": {
+    "unicode": "1F4D7",
+    "unicode_alternates": [],
+    "name": "green book",
+    "shortname": ":green_book:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["knowledge", "library", "read"],
+    "moji": "📗"
+  },
+  "green_heart": {
+    "unicode": "1F49A",
+    "unicode_alternates": [],
+    "name": "green heart",
+    "shortname": ":green_heart:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["affection", "like", "love", "valentines", "green", "heart", "love", "nature", "rebirth", "reborn", "jealous", "clingy", "envious", "possessive"],
+    "moji": "💚"
+  },
+  "grey_exclamation": {
+    "unicode": "2755",
+    "unicode_alternates": [],
+    "name": "white exclamation mark ornament",
+    "shortname": ":grey_exclamation:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["surprise"],
+    "moji": "❕"
+  },
+  "grey_question": {
+    "unicode": "2754",
+    "unicode_alternates": [],
+    "name": "white question mark ornament",
+    "shortname": ":grey_question:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["doubts"],
+    "moji": "❔"
+  },
+  "grimacing": {
+    "unicode": "1F62C",
+    "unicode_alternates": [],
+    "name": "grimacing face",
+    "shortname": ":grimacing:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["face", "grimace", "teeth", "grimace", "disapprove", "pain"],
+    "moji": "😬"
+  },
+  "grin": {
+    "unicode": "1F601",
+    "unicode_alternates": [],
+    "name": "grinning face with smiling eyes",
+    "shortname": ":grin:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["face", "happy", "joy", "smile", "grin", "grinning", "smiling", "smile", "smiley"],
+    "moji": "😁"
+  },
+  "grinning": {
+    "unicode": "1F600",
+    "unicode_alternates": [],
+    "name": "grinning face",
+    "shortname": ":grinning:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["face", "happy", "joy", "smile", "grin", "grinning", "smiling", "smile", "smiley"],
+    "moji": "🕧"
+  },
+  "guardsman": {
+    "unicode": "1F482",
+    "unicode_alternates": [],
+    "name": "guardsman",
+    "shortname": ":guardsman:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["british", "gb", "male", "man", "uk", "guardsman", "guard", "bearskin", "hat", "british", "queen", "ceremonial", "military"],
+    "moji": "💂"
+  },
+  "guitar": {
+    "unicode": "1F3B8",
+    "unicode_alternates": [],
+    "name": "guitar",
+    "shortname": ":guitar:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["instrument", "music", "guitar", "string", "music", "instrument", "jam", "rock", "acoustic", "electric"],
+    "moji": "🎸"
+  },
+  "gun": {
+    "unicode": "1F52B",
+    "unicode_alternates": [],
+    "name": "pistol",
+    "shortname": ":gun:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["violence", "weapon"],
+    "moji": "🔫"
+  },
+  "haircut": {
+    "unicode": "1F487",
+    "unicode_alternates": [],
+    "name": "haircut",
+    "shortname": ":haircut:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["female", "girl", "woman"],
+    "moji": "💇"
+  },
+  "hamburger": {
+    "unicode": "1F354",
+    "unicode_alternates": [],
+    "name": "hamburger",
+    "shortname": ":hamburger:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["food", "meat", "hamburger", "burger", "meat", "cow", "beef"],
+    "moji": "🍔"
+  },
+  "hammer": {
+    "unicode": "1F528",
+    "unicode_alternates": [],
+    "name": "hammer",
+    "shortname": ":hammer:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["done", "judge", "law", "ruling", "tools", "verdict"],
+    "moji": "🔨"
+  },
+  "hamster": {
+    "unicode": "1F439",
+    "unicode_alternates": [],
+    "name": "hamster face",
+    "shortname": ":hamster:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "nature"],
+    "moji": "🐹"
+  },
+  "hand_splayed": {
+    "unicode": "1F590",
+    "unicode_alternates": [],
+    "name": "raised hand with fingers splayed",
+    "shortname": ":hand_splayed:",
+    "category": "people",
+    "aliases": [":raised_hand_with_fingers_splayed:"],
+    "aliases_ascii": [],
+    "keywords": ["hi", "five", "stop", "halt"]
+  },
+  "hand_splayed_reverse": {
+    "unicode": "1F591",
+    "unicode_alternates": [],
+    "name": "reversed raised hand with fingers splayed",
+    "shortname": ":hand_splayed_reverse:",
+    "category": "people",
+    "aliases": [":reversed_raised_hand_with_fingers_splayed:"],
+    "aliases_ascii": [],
+    "keywords": ["hi", "five", "stop", "halt"]
+  },
+  "hand_victory": {
+    "unicode": "1F594",
+    "unicode_alternates": [],
+    "name": "reversed victory hand",
+    "shortname": ":hand_victory:",
+    "category": "people",
+    "aliases": [":reversed_victory_hand:"],
+    "aliases_ascii": [],
+    "keywords": ["fu"]
+  },
+  "handbag": {
+    "unicode": "1F45C",
+    "unicode_alternates": [],
+    "name": "handbag",
+    "shortname": ":handbag:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["accessories", "accessory", "bag", "fashion"],
+    "moji": "👜"
+  },
+  "hard_disk": {
+    "unicode": "1F5B4",
+    "unicode_alternates": [],
+    "name": "hard disk",
+    "shortname": ":hard_disk:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["save", "technology", "storage", "information", "computer", "drive", "megabyte", "gigabyte", "hd"]
+  },
+  "hash": {
+    "moji": "#⃣",
+    "unicode": "0023-20E3",
+    "unicode_alternates": ["0023-FE0F-20E3"],
+    "name": "number sign",
+    "shortname": ":hash:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["symbol"]
+  },
+  "hatched_chick": {
+    "unicode": "1F425",
+    "unicode_alternates": [],
+    "name": "front-facing baby chick",
+    "shortname": ":hatched_chick:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["baby", "chicken", "chick", "baby", "bird", "chicken", "young", "woman", "cute"],
+    "moji": "🐥"
+  },
+  "hatching_chick": {
+    "unicode": "1F423",
+    "unicode_alternates": [],
+    "name": "hatching chick",
+    "shortname": ":hatching_chick:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["born", "chicken", "egg", "chick", "egg", "baby", "bird", "chicken", "young", "woman", "cute"],
+    "moji": "🐣"
+  },
+  "headphones": {
+    "unicode": "1F3A7",
+    "unicode_alternates": [],
+    "name": "headphone",
+    "shortname": ":headphones:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["gadgets", "music", "score", "headphone", "sound", "music", "ears", "beats", "buds", "audio", "listen"],
+    "moji": "🎧"
+  },
+  "hear_no_evil": {
+    "unicode": "1F649",
+    "unicode_alternates": [],
+    "name": "hear-no-evil monkey",
+    "shortname": ":hear_no_evil:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "monkey", "monkey", "ears", "hear", "sound", "kikazaru"],
+    "moji": "🙉"
+  },
+  "heart": {
+    "moji": "❤",
+    "unicode": "2764",
+    "unicode_alternates": ["2764-FE0F"],
+    "name": "heavy black heart",
+    "shortname": ":heart:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": ["<3"],
+    "keywords": ["like", "love", "red", "pink", "black", "heart", "love", "passion", "romance", "intense", "desire", "death", "evil", "cold", "valentines"]
+  },
+  "heart_decoration": {
+    "unicode": "1F49F",
+    "unicode_alternates": [],
+    "name": "heart decoration",
+    "shortname": ":heart_decoration:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["like", "love", "purple-square"],
+    "moji": "💟"
+  },
+  "heart_eyes": {
+    "unicode": "1F60D",
+    "unicode_alternates": [],
+    "name": "smiling face with heart-shaped eyes",
+    "shortname": ":heart_eyes:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["affection", "crush", "face", "infatuation", "like", "love", "valentines", "smiling", "heart", "lovestruck", "love", "flirt", "smile", "heart-shaped"],
+    "moji": "😍"
+  },
+  "heart_eyes_cat": {
+    "unicode": "1F63B",
+    "unicode_alternates": [],
+    "name": "smiling cat face with heart-shaped eyes",
+    "shortname": ":heart_eyes_cat:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["affection", "animal", "cats", "like", "love", "valentines", "lovestruck", "love", "heart"],
+    "moji": "😻"
+  },
+  "heart_tip": {
+    "unicode": "1F394",
+    "unicode_alternates": [],
+    "name": "heart with tip on the left",
+    "shortname": ":heart_tip:",
+    "category": "celebration",
+    "aliases": [":heart_with_tip_on_the_left:"],
+    "aliases_ascii": [],
+    "keywords": ["affection", "like", "love", "valentines"]
+  },
+  "heartbeat": {
+    "unicode": "1F493",
+    "unicode_alternates": [],
+    "name": "beating heart",
+    "shortname": ":heartbeat:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["affection", "like", "love", "valentines"],
+    "moji": "💓"
+  },
+  "heartpulse": {
+    "unicode": "1F497",
+    "unicode_alternates": [],
+    "name": "growing heart",
+    "shortname": ":heartpulse:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["affection", "like", "love", "valentines"],
+    "moji": "💗"
+  },
+  "hearts": {
+    "unicode": "2665",
+    "unicode_alternates": ["2665-FE0F"],
+    "name": "black heart suit",
+    "shortname": ":hearts:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["cards", "poker"],
+    "moji": "♥"
+  },
+  "heavy_check_mark": {
+    "unicode": "2714",
+    "unicode_alternates": ["2714-FE0F"],
+    "name": "heavy check mark",
+    "shortname": ":heavy_check_mark:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["nike", "ok"],
+    "moji": "✔"
+  },
+  "heavy_division_sign": {
+    "unicode": "2797",
+    "unicode_alternates": [],
+    "name": "heavy division sign",
+    "shortname": ":heavy_division_sign:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["calculation", "divide", "math"],
+    "moji": "âž—"
+  },
+  "heavy_dollar_sign": {
+    "unicode": "1F4B2",
+    "unicode_alternates": [],
+    "name": "heavy dollar sign",
+    "shortname": ":heavy_dollar_sign:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["currency", "money", "payment", "dollar", "currency", "money", "cash", "sale", "purchase", "value"],
+    "moji": "💲"
+  },
+  "heavy_minus_sign": {
+    "unicode": "2796",
+    "unicode_alternates": [],
+    "name": "heavy minus sign",
+    "shortname": ":heavy_minus_sign:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["calculation", "math"],
+    "moji": "âž–"
+  },
+  "heavy_multiplication_x": {
+    "unicode": "2716",
+    "unicode_alternates": ["2716-FE0F"],
+    "name": "heavy multiplication x",
+    "shortname": ":heavy_multiplication_x:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["calculation", "math"],
+    "moji": "✖"
+  },
+  "heavy_plus_sign": {
+    "unicode": "2795",
+    "unicode_alternates": [],
+    "name": "heavy plus sign",
+    "shortname": ":heavy_plus_sign:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["calculation", "math"],
+    "moji": "âž•"
+  },
+  "helicopter": {
+    "unicode": "1F681",
+    "unicode_alternates": [],
+    "name": "helicopter",
+    "shortname": ":helicopter:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["transportation", "vehicle", "helicopter", "helo", "gyro", "gyrocopter"],
+    "moji": "🚁"
+  },
+  "herb": {
+    "unicode": "1F33F",
+    "unicode_alternates": [],
+    "name": "herb",
+    "shortname": ":herb:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["grass", "lawn", "medicine", "plant", "vegetable", "weed", "herb", "spice", "plant", "cook", "cooking"],
+    "moji": "🌿"
+  },
+  "hibiscus": {
+    "unicode": "1F33A",
+    "unicode_alternates": [],
+    "name": "hibiscus",
+    "shortname": ":hibiscus:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["flowers", "plant", "vegetable", "hibiscus", "flower", "warm"],
+    "moji": "🌺"
+  },
+  "high_brightness": {
+    "unicode": "1F506",
+    "unicode_alternates": [],
+    "name": "high brightness symbol",
+    "shortname": ":high_brightness:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["light", "summer", "sun"],
+    "moji": "🔆"
+  },
+  "high_heel": {
+    "unicode": "1F460",
+    "unicode_alternates": [],
+    "name": "high-heeled shoe",
+    "shortname": ":high_heel:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["fashion", "female", "shoes"],
+    "moji": "👠"
+  },
+  "hole": {
+    "unicode": "1F573",
+    "unicode_alternates": [],
+    "name": "hole",
+    "shortname": ":hole:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["pit", "well"]
+  },
+  "homes": {
+    "unicode": "1F3D8",
+    "unicode_alternates": [],
+    "name": "house buildings",
+    "shortname": ":homes:",
+    "category": "travel_places",
+    "aliases": [":house_buildings:"],
+    "aliases_ascii": [],
+    "keywords": ["home", "residence", "dwelling", "mansion", "bungalow", "ranch", "craftsman"]
+  },
+  "honey_pot": {
+    "unicode": "1F36F",
+    "unicode_alternates": [],
+    "name": "honey pot",
+    "shortname": ":honey_pot:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["bees", "sweet", "honey", "pot", "bees", "pooh", "bear"],
+    "moji": "🍯"
+  },
+  "horse": {
+    "unicode": "1F434",
+    "unicode_alternates": [],
+    "name": "horse face",
+    "shortname": ":horse:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "brown"],
+    "moji": "🐴"
+  },
+  "horse_racing": {
+    "unicode": "1F3C7",
+    "unicode_alternates": [],
+    "name": "horse racing",
+    "shortname": ":horse_racing:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "betting", "competition", "horse", "race", "racing", "jockey", "triple crown"],
+    "moji": "🏇"
+  },
+  "hospital": {
+    "unicode": "1F3E5",
+    "unicode_alternates": [],
+    "name": "hospital",
+    "shortname": ":hospital:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["building", "doctor", "health", "surgery"],
+    "moji": "🏥"
+  },
+  "hot_pepper": {
+    "unicode": "1F336",
+    "unicode_alternates": [],
+    "name": "hot pepper",
+    "shortname": ":hot_pepper:",
+    "category": "food_drink",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["food", "nature", "spicy", "chili", "cayenne", "habanero", "jalapeno"]
+  },
+  "hotel": {
+    "unicode": "1F3E8",
+    "unicode_alternates": [],
+    "name": "hotel",
+    "shortname": ":hotel:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["accomodation", "building", "checkin", "whotel", "hotel", "motel", "holiday inn", "hospital"],
+    "moji": "🏨"
+  },
+  "hotsprings": {
+    "unicode": "2668",
+    "unicode_alternates": ["2668-FE0F"],
+    "name": "hot springs",
+    "shortname": ":hotsprings:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["bath", "relax", "warm"],
+    "moji": "♨"
+  },
+  "hourglass": {
+    "unicode": "231B",
+    "unicode_alternates": ["231B-FE0F"],
+    "name": "hourglass",
+    "shortname": ":hourglass:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["clock", "oldschool", "time"],
+    "moji": "⌛"
+  },
+  "hourglass_flowing_sand": {
+    "unicode": "23F3",
+    "unicode_alternates": [],
+    "name": "hourglass with flowing sand",
+    "shortname": ":hourglass_flowing_sand:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["countdown", "oldschool", "time"],
+    "moji": "⏳"
+  },
+  "house": {
+    "unicode": "1F3E0",
+    "unicode_alternates": [],
+    "name": "house building",
+    "shortname": ":house:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["building", "home", "house", "home", "residence", "dwelling", "mansion", "bungalow", "ranch", "craftsman"],
+    "moji": "🏠"
+  },
+  "house_abandoned": {
+    "unicode": "1F3DA",
+    "unicode_alternates": [],
+    "name": "derelict house building",
+    "shortname": ":house_abandoned:",
+    "category": "travel_places",
+    "aliases": [":derelict_house_building:"],
+    "aliases_ascii": [],
+    "keywords": ["home", "residence", "dwelling", "mansion", "bungalow", "ranch", "craftsman", "boarded", "abandoned", "vacant", "run down", "shoddy"]
+  },
+  "house_with_garden": {
+    "unicode": "1F3E1",
+    "unicode_alternates": [],
+    "name": "house with garden",
+    "shortname": ":house_with_garden:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["home", "nature", "plant"],
+    "moji": "🏡"
+  },
+  "hushed": {
+    "unicode": "1F62F",
+    "unicode_alternates": [],
+    "name": "hushed face",
+    "shortname": ":hushed:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["face", "woo", "quiet", "hush", "whisper", "silent"],
+    "moji": "😯"
+  },
+  "ice_cream": {
+    "unicode": "1F368",
+    "unicode_alternates": [],
+    "name": "ice cream",
+    "shortname": ":ice_cream:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["desert", "food", "hot", "icecream", "ice", "cream", "dairy", "dessert", "cold", "soft", "serve", "cone", "waffle"],
+    "moji": "🍨"
+  },
+  "icecream": {
+    "unicode": "1F366",
+    "unicode_alternates": [],
+    "name": "soft ice cream",
+    "shortname": ":icecream:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["desert", "food", "hot", "icecream", "ice", "cream", "dairy", "dessert", "cold", "soft", "serve", "cone", "yogurt"],
+    "moji": "🍦"
+  },
+  "ideograph_advantage": {
+    "unicode": "1F250",
+    "unicode_alternates": [],
+    "name": "circled ideograph advantage",
+    "shortname": ":ideograph_advantage:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["chinese", "get", "kanji", "obtain"],
+    "moji": "🉐"
+  },
+  "imp": {
+    "unicode": "1F47F",
+    "unicode_alternates": [],
+    "name": "imp",
+    "shortname": ":imp:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["angry", "devil", "evil", "horns", "cute", "devil"],
+    "moji": "👿"
+  },
+  "inbox_tray": {
+    "unicode": "1F4E5",
+    "unicode_alternates": [],
+    "name": "inbox tray",
+    "shortname": ":inbox_tray:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["documents", "email"],
+    "moji": "📥"
+  },
+  "incoming_envelope": {
+    "unicode": "1F4E8",
+    "unicode_alternates": [],
+    "name": "incoming envelope",
+    "shortname": ":incoming_envelope:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["email", "inbox"],
+    "moji": "📨"
+  },
+  "info": {
+    "unicode": "1F6C8",
+    "unicode_alternates": [],
+    "name": "circled information source",
+    "shortname": ":info:",
+    "category": "objects_symbols",
+    "aliases": [":circled_information_source:"],
+    "aliases_ascii": [],
+    "keywords": ["icon"]
+  },
+  "information_desk_person": {
+    "unicode": "1F481",
+    "unicode_alternates": [],
+    "name": "information desk person",
+    "shortname": ":information_desk_person:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["female", "girl", "human", "woman", "information", "help", "question", "answer", "sassy", "unimpressed", "attitude", "snarky"],
+    "moji": "💁"
+  },
+  "information_source": {
+    "unicode": "2139",
+    "unicode_alternates": ["2139-FE0F"],
+    "name": "information source",
+    "shortname": ":information_source:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["alphabet", "blue-square", "letter"],
+    "moji": "ℹ"
+  },
+  "innocent": {
+    "unicode": "1F607",
+    "unicode_alternates": [],
+    "name": "smiling face with halo",
+    "shortname": ":innocent:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": ["O:-)", "0:-3", "0:3", "0:-)", "0:)", "0;^)", "O:-)", "O:)", "O;-)", "O=)", "0;-)", "O:-3", "O:3"],
+    "keywords": ["angel", "face", "halo", "halo", "angel", "innocent", "ring", "circle", "heaven"],
+    "moji": "😇"
+  },
+  "interrobang": {
+    "unicode": "2049",
+    "unicode_alternates": ["2049-FE0F"],
+    "name": "exclamation question mark",
+    "shortname": ":interrobang:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["punctuation", "surprise", "wat"],
+    "moji": "⁉"
+  },
+  "iphone": {
+    "unicode": "1F4F1",
+    "unicode_alternates": [],
+    "name": "mobile phone",
+    "shortname": ":iphone:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["apple", "dial", "gadgets", "technology"],
+    "moji": "📱"
+  },
+  "island": {
+    "unicode": "1F3DD",
+    "unicode_alternates": [],
+    "name": "desert island",
+    "shortname": ":island:",
+    "category": "travel_places",
+    "aliases": [":desert_island:"],
+    "aliases_ascii": [],
+    "keywords": ["land", "solitude", "alone"]
+  },
+  "izakaya_lantern": {
+    "unicode": "1F3EE",
+    "unicode_alternates": [],
+    "name": "izakaya lantern",
+    "shortname": ":izakaya_lantern:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["light", "izakaya", "lantern", "stay", "drink", "alcohol", "bar", "sake", "restaurant"],
+    "moji": "🏮"
+  },
+  "jack_o_lantern": {
+    "unicode": "1F383",
+    "unicode_alternates": [],
+    "name": "jack-o-lantern",
+    "shortname": ":jack_o_lantern:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["halloween", "jack-o-lantern", "pumpkin", "halloween", "holiday", "carve", "autumn", "fall", "october", "saints", "costume", "spooky", "horror", "scary", "scared", "dead"],
+    "moji": "🎃"
+  },
+  "japan": {
+    "unicode": "1F5FE",
+    "unicode_alternates": [],
+    "name": "silhouette of japan",
+    "shortname": ":japan:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["nation"],
+    "moji": "🗾"
+  },
+  "japanese_castle": {
+    "unicode": "1F3EF",
+    "unicode_alternates": [],
+    "name": "japanese castle",
+    "shortname": ":japanese_castle:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["building", "photo", "castle", "japanese", "residence", "royalty", "fort", "fortified", "fortress"],
+    "moji": "🏯"
+  },
+  "japanese_goblin": {
+    "unicode": "1F47A",
+    "unicode_alternates": [],
+    "name": "japanese goblin",
+    "shortname": ":japanese_goblin:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["evil", "mask", "red", "japanese", "tengu", "supernatural", "avian", "demon", "goblin", "mask", "theater", "nose", "frown", "mustache", "anger", "frustration"],
+    "moji": "👺"
+  },
+  "japanese_ogre": {
+    "unicode": "1F479",
+    "unicode_alternates": [],
+    "name": "japanese ogre",
+    "shortname": ":japanese_ogre:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["monster", "japanese", "oni", "demon", "troll", "ogre", "folklore", "monster", "devil", "mask", "theater", "horns", "teeth"],
+    "moji": "👹"
+  },
+  "jeans": {
+    "unicode": "1F456",
+    "unicode_alternates": [],
+    "name": "jeans",
+    "shortname": ":jeans:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["fashion", "shopping", "jeans", "pants", "blue", "denim", "levi&#039;s", "levi", "designer", "work", "skinny"],
+    "moji": "👖"
+  },
+  "jet_up": {
+    "unicode": "1F6E6",
+    "unicode_alternates": [],
+    "name": "up-pointing military airplane",
+    "shortname": ":jet_up:",
+    "category": "travel_places",
+    "aliases": [":up_pointing_military_airplane:"],
+    "aliases_ascii": [],
+    "keywords": ["jet"]
+  },
+  "joy": {
+    "unicode": "1F602",
+    "unicode_alternates": [],
+    "name": "face with tears of joy",
+    "shortname": ":joy:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [":')", ":'-)"],
+    "keywords": ["cry", "face", "haha", "happy", "tears", "tears", "cry", "joy", "happy", "weep"],
+    "moji": "😂"
+  },
+  "joy_cat": {
+    "unicode": "1F639",
+    "unicode_alternates": [],
+    "name": "cat face with tears of joy",
+    "shortname": ":joy_cat:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "cats", "haha", "happy", "tears", "happy", "tears", "cry", "joy"],
+    "moji": "😹"
+  },
+  "joystick": {
+    "unicode": "1F579",
+    "unicode_alternates": [],
+    "name": "joystick",
+    "shortname": ":joystick:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["games", "atari", "controller"]
+  },
+  "key": {
+    "unicode": "1F511",
+    "unicode_alternates": [],
+    "name": "key",
+    "shortname": ":key:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["door", "lock", "password"],
+    "moji": "🔑"
+  },
+  "key2": {
+    "unicode": "1F5DD",
+    "unicode_alternates": [],
+    "name": "old key",
+    "shortname": ":key2:",
+    "category": "objects_symbols",
+    "aliases": [":old_key:"],
+    "aliases_ascii": [],
+    "keywords": ["door", "lock", "password", "skeleton"]
+  },
+  "keyboard": {
+    "unicode": "1F5AE",
+    "unicode_alternates": [],
+    "name": "wired keyboard",
+    "shortname": ":keyboard:",
+    "category": "objects_symbols",
+    "aliases": [":wired_keyboard:"],
+    "aliases_ascii": [],
+    "keywords": ["typing", "keys", "input", "device"]
+  },
+  "keyboard_mouse": {
+    "unicode": "1F5A6",
+    "unicode_alternates": [],
+    "name": "keyboard and mouse",
+    "shortname": ":keyboard_mouse:",
+    "category": "objects_symbols",
+    "aliases": [":keyboard_and_mouse:"],
+    "aliases_ascii": [],
+    "keywords": ["computer", "input", "desktop"]
+  },
+  "keyboard_with_jacks": {
+    "unicode": "1F398",
+    "unicode_alternates": [],
+    "name": "musical keyboard with jacks",
+    "shortname": ":keyboard_with_jacks:",
+    "category": "objects_symbols",
+    "aliases": [":musical_keyboard_with_jacks:"],
+    "aliases_ascii": [],
+    "keywords": ["music", "instrument", "midi"]
+  },
+  "keycap_ten": {
+    "unicode": "1F51F",
+    "unicode_alternates": [],
+    "name": "keycap ten",
+    "shortname": ":keycap_ten:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["10", "blue-square", "numbers"],
+    "moji": "🔟"
+  },
+  "kimono": {
+    "unicode": "1F458",
+    "unicode_alternates": [],
+    "name": "kimono",
+    "shortname": ":kimono:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["dress", "fashion", "female", "japanese", "women"],
+    "moji": "👘"
+  },
+  "kiss": {
+    "unicode": "1F48B",
+    "unicode_alternates": [],
+    "name": "kiss mark",
+    "shortname": ":kiss:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["affection", "face", "like", "lips", "love", "valentines"],
+    "moji": "💋"
+  },
+  "kiss_mm": {
+    "unicode": "1F468-2764-1F48B-1F468",
+    "unicode_alternates": ["1F468-200D-2764-FE0F-200D-1F48B-200D-1F468"],
+    "name": "kiss (man,man)",
+    "shortname": ":kiss_mm:",
+    "category": "people",
+    "aliases": [":couplekiss_mm:"],
+    "aliases_ascii": [],
+    "keywords": ["dating", "like", "love", "marriage", "valentines", "couple"]
+  },
+  "kiss_ww": {
+    "unicode": "1F469-2764-1F48B-1F469",
+    "unicode_alternates": ["1F469-200D-2764-FE0F-200D-1F48B-200D-1F469"],
+    "name": "kiss (woman,woman)",
+    "shortname": ":kiss_ww:",
+    "category": "people",
+    "aliases": [":couplekiss_ww:"],
+    "aliases_ascii": [],
+    "keywords": ["dating", "like", "love", "marriage", "valentines", "couple"]
+  },
+  "kissing": {
+    "unicode": "1F617",
+    "unicode_alternates": [],
+    "name": "kissing face",
+    "shortname": ":kissing:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["3", "face", "infatuation", "like", "love", "valentines", "kissing", "kiss", "pucker", "lips", "smooch"],
+    "moji": "😗"
+  },
+  "kissing_cat": {
+    "unicode": "1F63D",
+    "unicode_alternates": [],
+    "name": "kissing cat face with closed eyes",
+    "shortname": ":kissing_cat:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "cats", "passion", "kiss", "puckered", "heart", "love"],
+    "moji": "😽"
+  },
+  "kissing_closed_eyes": {
+    "unicode": "1F61A",
+    "unicode_alternates": [],
+    "name": "kissing face with closed eyes",
+    "shortname": ":kissing_closed_eyes:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["affection", "face", "infatuation", "like", "love", "valentines", "kissing", "kiss", "passion", "puckered", "heart", "love", "smooch"],
+    "moji": "😚"
+  },
+  "kissing_heart": {
+    "unicode": "1F618",
+    "unicode_alternates": [],
+    "name": "face throwing a kiss",
+    "shortname": ":kissing_heart:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [":*", ":-*", "=*", ":^*"],
+    "keywords": ["affection", "face", "infatuation", "kiss", "blowing kiss", "heart", "love", "lips", "like", "love", "valentines"],
+    "moji": "😘"
+  },
+  "kissing_smiling_eyes": {
+    "unicode": "1F619",
+    "unicode_alternates": [],
+    "name": "kissing face with smiling eyes",
+    "shortname": ":kissing_smiling_eyes:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["affection", "face", "infatuation", "valentines", "kissing", "kiss", "smile", "pucker", "lips", "smooch"],
+    "moji": "😙"
+  },
+  "knife": {
+    "unicode": "1F52A",
+    "unicode_alternates": [],
+    "name": "hocho",
+    "shortname": ":knife:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": [],
+    "moji": "🔪"
+  },
+  "koala": {
+    "unicode": "1F428",
+    "unicode_alternates": [],
+    "name": "koala",
+    "shortname": ":koala:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "nature"],
+    "moji": "🐨"
+  },
+  "koko": {
+    "unicode": "1F201",
+    "unicode_alternates": [],
+    "name": "squared katakana koko",
+    "shortname": ":koko:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blue-square", "destination", "here", "japanese", "katakana"],
+    "moji": "🈁"
+  },
+  "label": {
+    "unicode": "1F3F7",
+    "unicode_alternates": [],
+    "name": "label",
+    "shortname": ":label:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["tag"]
+  },
+  "large_blue_circle": {
+    "unicode": "1F535",
+    "unicode_alternates": [],
+    "name": "large blue circle",
+    "shortname": ":large_blue_circle:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": [],
+    "moji": "🔵"
+  },
+  "large_blue_diamond": {
+    "unicode": "1F537",
+    "unicode_alternates": [],
+    "name": "large blue diamond",
+    "shortname": ":large_blue_diamond:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["shape"],
+    "moji": "🔷"
+  },
+  "large_orange_diamond": {
+    "unicode": "1F536",
+    "unicode_alternates": [],
+    "name": "large orange diamond",
+    "shortname": ":large_orange_diamond:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["shape"],
+    "moji": "🔶"
+  },
+  "last_quarter_moon": {
+    "unicode": "1F317",
+    "unicode_alternates": [],
+    "name": "last quarter moon symbol",
+    "shortname": ":last_quarter_moon:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["nature", "moon", "last", "quarter", "sky", "night", "cheese", "phase"],
+    "moji": "🌗"
+  },
+  "last_quarter_moon_with_face": {
+    "unicode": "1F31C",
+    "unicode_alternates": [],
+    "name": "last quarter moon with face",
+    "shortname": ":last_quarter_moon_with_face:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["nature", "moon", "last", "quarter", "anthropomorphic", "face", "sky", "night", "cheese", "phase"],
+    "moji": "🌜"
+  },
+  "laughing": {
+    "unicode": "1F606",
+    "unicode_alternates": [],
+    "name": "smiling face with open mouth and tightly-closed ey",
+    "shortname": ":laughing:",
+    "category": "emoticons",
+    "aliases": [":satisfied:"],
+    "aliases_ascii": [">:)", ">;)", ">:-)", ">=)"],
+    "keywords": ["happy", "joy", "lol", "smiling", "laughing", "laugh"],
+    "moji": "😆"
+  },
+  "leaves": {
+    "unicode": "1F343",
+    "unicode_alternates": [],
+    "name": "leaf fluttering in wind",
+    "shortname": ":leaves:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["grass", "lawn", "nature", "plant", "tree", "vegetable", "leaves", "leaf", "wind", "float", "fluttering"],
+    "moji": "🍃"
+  },
+  "ledger": {
+    "unicode": "1F4D2",
+    "unicode_alternates": [],
+    "name": "ledger",
+    "shortname": ":ledger:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["notes", "paper"],
+    "moji": "📒"
+  },
+  "left_luggage": {
+    "unicode": "1F6C5",
+    "unicode_alternates": [],
+    "name": "left luggage",
+    "shortname": ":left_luggage:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blue-square", "travel", "bag", "baggage", "luggage", "travel"],
+    "moji": "🛅"
+  },
+  "left_receiver": {
+    "unicode": "1F57B",
+    "unicode_alternates": [],
+    "name": "left hand telephone receiver",
+    "shortname": ":left_receiver:",
+    "category": "objects_symbols",
+    "aliases": [":left_hand_telephone_receiver:"],
+    "aliases_ascii": [],
+    "keywords": ["communication", "dial", "technology"]
+  },
+  "left_right_arrow": {
+    "unicode": "2194",
+    "unicode_alternates": ["2194-FE0F"],
+    "name": "left right arrow",
+    "shortname": ":left_right_arrow:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["shape"],
+    "moji": "↔"
+  },
+  "leftwards_arrow_with_hook": {
+    "unicode": "21A9",
+    "unicode_alternates": ["21A9-FE0F"],
+    "name": "leftwards arrow with hook",
+    "shortname": ":leftwards_arrow_with_hook:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": [],
+    "moji": "↩"
+  },
+  "lemon": {
+    "unicode": "1F34B",
+    "unicode_alternates": [],
+    "name": "lemon",
+    "shortname": ":lemon:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["fruit", "nature", "lemon", "yellow", "citrus"],
+    "moji": "🍋"
+  },
+  "leo": {
+    "unicode": "264C",
+    "unicode_alternates": ["264C-FE0F"],
+    "name": "leo",
+    "shortname": ":leo:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["leo", "lion", "astrology", "greek", "constellation", "stars", "zodiac", "sign", "purple-square", "sign", "zodiac", "horoscope"],
+    "moji": "♌"
+  },
+  "leopard": {
+    "unicode": "1F406",
+    "unicode_alternates": [],
+    "name": "leopard",
+    "shortname": ":leopard:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "nature", "leopard", "cat", "spot", "spotted", "sexy"],
+    "moji": "🐆"
+  },
+  "level_slider": {
+    "unicode": "1F39A",
+    "unicode_alternates": [],
+    "name": "level slider",
+    "shortname": ":level_slider:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["controls"]
+  },
+  "levitate": {
+    "unicode": "1F574",
+    "unicode_alternates": [],
+    "name": "man in business suit levitating",
+    "shortname": ":levitate:",
+    "category": "people",
+    "aliases": [":man_in_business_suit_levitating:"],
+    "aliases_ascii": [],
+    "keywords": ["hover", "exclamation"]
+  },
+  "libra": {
+    "unicode": "264E",
+    "unicode_alternates": ["264E-FE0F"],
+    "name": "libra",
+    "shortname": ":libra:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["libra", "scales", "astrology", "greek", "constellation", "stars", "zodiac", "sign", "purple-square", "sign", "zodiac", "horoscope"],
+    "moji": "♎"
+  },
+  "lifter": {
+    "unicode": "1F3CB",
+    "unicode_alternates": [],
+    "name": "weight lifter",
+    "shortname": ":lifter:",
+    "category": "activity",
+    "aliases": [":weight_lifter:"],
+    "aliases_ascii": [],
+    "keywords": ["bench", "press", "squats", "deadlift"]
+  },
+  "light_check_mark": {
+    "unicode": "1F5F8",
+    "unicode_alternates": [],
+    "name": "light check mark",
+    "shortname": ":light_check_mark:",
+    "category": "objects_symbols",
+    "aliases": [":light_mark:"],
+    "aliases_ascii": [],
+    "keywords": ["vote"]
+  },
+  "light_rail": {
+    "unicode": "1F688",
+    "unicode_alternates": [],
+    "name": "light rail",
+    "shortname": ":light_rail:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["transportation", "vehicle", "train", "rail", "light"],
+    "moji": "🚈"
+  },
+  "link": {
+    "unicode": "1F517",
+    "unicode_alternates": [],
+    "name": "link symbol",
+    "shortname": ":link:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["rings", "url"],
+    "moji": "🔗"
+  },
+  "lips": {
+    "unicode": "1F444",
+    "unicode_alternates": [],
+    "name": "mouth",
+    "shortname": ":lips:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["kiss", "mouth"],
+    "moji": "👄"
+  },
+  "lips2": {
+    "unicode": "1F5E2",
+    "unicode_alternates": [],
+    "name": "lips",
+    "shortname": ":lips2:",
+    "category": "people",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["kiss", "mouth"]
+  },
+  "lipstick": {
+    "unicode": "1F484",
+    "unicode_alternates": [],
+    "name": "lipstick",
+    "shortname": ":lipstick:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["fashion", "female", "girl"],
+    "moji": "💄"
+  },
+  "lock": {
+    "unicode": "1F512",
+    "unicode_alternates": [],
+    "name": "lock",
+    "shortname": ":lock:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["password", "security"],
+    "moji": "🔒"
+  },
+  "lock_with_ink_pen": {
+    "unicode": "1F50F",
+    "unicode_alternates": [],
+    "name": "lock with ink pen",
+    "shortname": ":lock_with_ink_pen:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["secret", "security"],
+    "moji": "🔏"
+  },
+  "lollipop": {
+    "unicode": "1F36D",
+    "unicode_alternates": [],
+    "name": "lollipop",
+    "shortname": ":lollipop:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["candy", "food", "snack", "sweet", "lollipop", "stick", "lick", "sweet", "sugar", "candy"],
+    "moji": "🍭"
+  },
+  "loop": {
+    "unicode": "27BF",
+    "unicode_alternates": [],
+    "name": "double curly loop",
+    "shortname": ":loop:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["curly"],
+    "moji": "âž¿"
+  },
+  "loud_sound": {
+    "unicode": "1F50A",
+    "unicode_alternates": [],
+    "name": "speaker with three sound waves",
+    "shortname": ":loud_sound:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": [],
+    "moji": "🔊"
+  },
+  "loudspeaker": {
+    "unicode": "1F4E2",
+    "unicode_alternates": [],
+    "name": "public address loudspeaker",
+    "shortname": ":loudspeaker:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["sound", "volume"],
+    "moji": "📢"
+  },
+  "love_hotel": {
+    "unicode": "1F3E9",
+    "unicode_alternates": [],
+    "name": "love hotel",
+    "shortname": ":love_hotel:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["affection", "dating", "like", "love", "hotel", "love", "sex", "romance", "leisure", "adultery", "prostitution", "hospital", "birth", "happy"],
+    "moji": "🏩"
+  },
+  "love_letter": {
+    "unicode": "1F48C",
+    "unicode_alternates": [],
+    "name": "love letter",
+    "shortname": ":love_letter:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["affection", "email", "envelope", "like", "valentines", "love", "letter", "kiss", "heart"],
+    "moji": "💌"
+  },
+  "low_brightness": {
+    "unicode": "1F505",
+    "unicode_alternates": [],
+    "name": "low brightness symbol",
+    "shortname": ":low_brightness:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["summer", "sun"],
+    "moji": "🔅"
+  },
+  "m": {
+    "unicode": "24C2",
+    "unicode_alternates": ["24C2-FE0F"],
+    "name": "circled latin capital letter m",
+    "shortname": ":m:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["alphabet", "blue-circle", "letter"],
+    "moji": "â“‚"
+  },
+  "mag": {
+    "unicode": "1F50D",
+    "unicode_alternates": [],
+    "name": "left-pointing magnifying glass",
+    "shortname": ":mag:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["search", "zoom", "detective", "investigator", "detail", "details"],
+    "moji": "🔍"
+  },
+  "mag_right": {
+    "unicode": "1F50E",
+    "unicode_alternates": [],
+    "name": "right-pointing magnifying glass",
+    "shortname": ":mag_right:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["search", "zoom", "detective", "investigator", "detail", "details"],
+    "moji": "🔎"
+  },
+  "mahjong": {
+    "unicode": "1F004",
+    "unicode_alternates": ["1F004-FE0F"],
+    "name": "mahjong tile red dragon",
+    "shortname": ":mahjong:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["chinese", "game", "kanji"],
+    "moji": "🀄"
+  },
+  "mailbox": {
+    "unicode": "1F4EB",
+    "unicode_alternates": [],
+    "name": "closed mailbox with raised flag",
+    "shortname": ":mailbox:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["communication", "email", "inbox"],
+    "moji": "📫"
+  },
+  "mailbox_closed": {
+    "unicode": "1F4EA",
+    "unicode_alternates": [],
+    "name": "closed mailbox with lowered flag",
+    "shortname": ":mailbox_closed:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["communication", "email", "inbox"],
+    "moji": "📪"
+  },
+  "mailbox_with_mail": {
+    "unicode": "1F4EC",
+    "unicode_alternates": [],
+    "name": "open mailbox with raised flag",
+    "shortname": ":mailbox_with_mail:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["communication", "email", "inbox"],
+    "moji": "📬"
+  },
+  "mailbox_with_no_mail": {
+    "unicode": "1F4ED",
+    "unicode_alternates": [],
+    "name": "open mailbox with lowered flag",
+    "shortname": ":mailbox_with_no_mail:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["email", "inbox"],
+    "moji": "📭"
+  },
+  "man": {
+    "unicode": "1F468",
+    "unicode_alternates": [],
+    "name": "man",
+    "shortname": ":man:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["classy", "dad", "father", "guy", "mustashe"],
+    "moji": "👨"
+  },
+  "man_with_gua_pi_mao": {
+    "unicode": "1F472",
+    "unicode_alternates": [],
+    "name": "man with gua pi mao",
+    "shortname": ":man_with_gua_pi_mao:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["boy", "male", "skullcap", "chinese", "asian", "qing"],
+    "moji": "👲"
+  },
+  "man_with_turban": {
+    "unicode": "1F473",
+    "unicode_alternates": [],
+    "name": "man with turban",
+    "shortname": ":man_with_turban:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["male", "turban", "headdress", "headwear", "pagri", "india", "indian", "mummy", "wisdom", "peace"],
+    "moji": "👳"
+  },
+  "mans_shoe": {
+    "unicode": "1F45E",
+    "unicode_alternates": [],
+    "name": "mans shoe",
+    "shortname": ":mans_shoe:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["fashion", "male"],
+    "moji": "👞"
+  },
+  "map": {
+    "unicode": "1F5FA",
+    "unicode_alternates": [],
+    "name": "world map",
+    "shortname": ":map:",
+    "category": "travel_places",
+    "aliases": [":world_map:"],
+    "aliases_ascii": [],
+    "keywords": ["atlas", "earth", "cartography"]
+  },
+  "maple_leaf": {
+    "unicode": "1F341",
+    "unicode_alternates": [],
+    "name": "maple leaf",
+    "shortname": ":maple_leaf:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["canada", "nature", "plant", "vegetable", "maple", "leaf", "syrup", "canada", "tree"],
+    "moji": "🍁"
+  },
+  "mask": {
+    "unicode": "1F637",
+    "unicode_alternates": [],
+    "name": "face with medical mask",
+    "shortname": ":mask:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["face", "ill", "sick", "sick", "virus", "flu", "medical", "mask"],
+    "moji": "😷"
+  },
+  "massage": {
+    "unicode": "1F486",
+    "unicode_alternates": [],
+    "name": "face massage",
+    "shortname": ":massage:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["female", "girl", "woman"],
+    "moji": "💆"
+  },
+  "meat_on_bone": {
+    "unicode": "1F356",
+    "unicode_alternates": [],
+    "name": "meat on bone",
+    "shortname": ":meat_on_bone:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["food", "good", "meat", "bone", "animal", "cooked"],
+    "moji": "🍖"
+  },
+  "medal": {
+    "unicode": "1F3C5",
+    "unicode_alternates": [],
+    "name": "sports medal",
+    "shortname": ":medal:",
+    "category": "activity",
+    "aliases": [":sports_medal:"],
+    "aliases_ascii": [],
+    "keywords": ["award", "ceremony", "contest", "ftw", "place", "win", "first", "show", "reward", "achievement"]
+  },
+  "mega": {
+    "unicode": "1F4E3",
+    "unicode_alternates": [],
+    "name": "cheering megaphone",
+    "shortname": ":mega:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["sound", "speaker", "volume"],
+    "moji": "📣"
+  },
+  "melon": {
+    "unicode": "1F348",
+    "unicode_alternates": [],
+    "name": "melon",
+    "shortname": ":melon:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["food", "fruit", "nature", "melon", "cantaloupe", "honeydew"],
+    "moji": "🍈"
+  },
+  "mens": {
+    "unicode": "1F6B9",
+    "unicode_alternates": [],
+    "name": "mens symbol",
+    "shortname": ":mens:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["restroom", "toilet", "wc", "men", "bathroom", "restroom", "sign", "boy", "male", "avatar"],
+    "moji": "🚹"
+  },
+  "metro": {
+    "unicode": "1F687",
+    "unicode_alternates": [],
+    "name": "metro",
+    "shortname": ":metro:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blue-square", "mrt", "transportation", "tube", "underground", "metro", "subway", "underground", "train"],
+    "moji": "🚇"
+  },
+  "microphone": {
+    "unicode": "1F3A4",
+    "unicode_alternates": [],
+    "name": "microphone",
+    "shortname": ":microphone:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["PA", "music", "sound", "microphone", "mic", "audio", "sound", "voice", "karaoke"],
+    "moji": "🎤"
+  },
+  "microphone2": {
+    "unicode": "1F399",
+    "unicode_alternates": [],
+    "name": "studio microphone",
+    "shortname": ":microphone2:",
+    "category": "objects_symbols",
+    "aliases": [":studio_microphone:"],
+    "aliases_ascii": [],
+    "keywords": ["mic", "audio", "recording"]
+  },
+  "microscope": {
+    "unicode": "1F52C",
+    "unicode_alternates": [],
+    "name": "microscope",
+    "shortname": ":microscope:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["experiment", "laboratory", "zoomin"],
+    "moji": "🔬"
+  },
+  "middle_finger": {
+    "unicode": "1F595",
+    "unicode_alternates": [],
+    "name": "reversed hand with middle finger extended",
+    "shortname": ":middle_finger:",
+    "category": "people",
+    "aliases": [":reversed_hand_with_middle_finger_extended:"],
+    "aliases_ascii": [],
+    "keywords": ["fu"]
+  },
+  "military_medal": {
+    "unicode": "1F396",
+    "unicode_alternates": [],
+    "name": "military medal",
+    "shortname": ":military_medal:",
+    "category": "celebration",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["honor", "acknowledgment", "purple heart", "heroism", "veteran"]
+  },
+  "milky_way": {
+    "unicode": "1F30C",
+    "unicode_alternates": [],
+    "name": "milky way",
+    "shortname": ":milky_way:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["photo", "space", "milky", "galaxy", "star", "stars", "planets", "space", "sky"],
+    "moji": "🌌"
+  },
+  "minibus": {
+    "unicode": "1F690",
+    "unicode_alternates": [],
+    "name": "minibus",
+    "shortname": ":minibus:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["car", "transportation", "vehicle", "bus", "city", "transport", "transportation"],
+    "moji": "🚐"
+  },
+  "minidisc": {
+    "unicode": "1F4BD",
+    "unicode_alternates": [],
+    "name": "minidisc",
+    "shortname": ":minidisc:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["data", "disc", "disk", "record", "technology"],
+    "moji": "💽"
+  },
+  "mobile_phone_off": {
+    "unicode": "1F4F4",
+    "unicode_alternates": [],
+    "name": "mobile phone off",
+    "shortname": ":mobile_phone_off:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["mute"],
+    "moji": "📴"
+  },
+  "money_with_wings": {
+    "unicode": "1F4B8",
+    "unicode_alternates": [],
+    "name": "money with wings",
+    "shortname": ":money_with_wings:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["bills", "dollar", "payment", "money", "wings", "easy", "spend", "work", "lost", "blown", "burned", "gift", "cash", "dollar"],
+    "moji": "💸"
+  },
+  "moneybag": {
+    "unicode": "1F4B0",
+    "unicode_alternates": [],
+    "name": "money bag",
+    "shortname": ":moneybag:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["coins", "dollar", "payment"],
+    "moji": "💰"
+  },
+  "monkey": {
+    "unicode": "1F412",
+    "unicode_alternates": [],
+    "name": "monkey",
+    "shortname": ":monkey:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "nature", "monkey", "primate", "banana", "silly"],
+    "moji": "🐒"
+  },
+  "monkey_face": {
+    "unicode": "1F435",
+    "unicode_alternates": [],
+    "name": "monkey face",
+    "shortname": ":monkey_face:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "nature"],
+    "moji": "🐵"
+  },
+  "monorail": {
+    "unicode": "1F69D",
+    "unicode_alternates": [],
+    "name": "monorail",
+    "shortname": ":monorail:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["transportation", "vehicle", "train", "mono", "rail", "transport"],
+    "moji": "🚝"
+  },
+  "mood_bubble": {
+    "unicode": "1F5F0",
+    "unicode_alternates": [],
+    "name": "mood bubble",
+    "shortname": ":mood_bubble:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["balloon", "conversation", "communication", "comic", "feeling"]
+  },
+  "mood_bubble_lightning": {
+    "unicode": "1F5F1",
+    "unicode_alternates": [],
+    "name": "lightning mood bubble",
+    "shortname": ":mood_bubble_lightning:",
+    "category": "objects_symbols",
+    "aliases": [":lightning_mood_bubble:"],
+    "aliases_ascii": [],
+    "keywords": ["balloon", "conversation", "communication", "comic", "feeling"]
+  },
+  "mood_lightning": {
+    "unicode": "1F5F2",
+    "unicode_alternates": [],
+    "name": "lightning mood",
+    "shortname": ":mood_lightning:",
+    "category": "objects_symbols",
+    "aliases": [":lightning_mood:"],
+    "aliases_ascii": [],
+    "keywords": ["zap", "electric", "current"]
+  },
+  "mortar_board": {
+    "unicode": "1F393",
+    "unicode_alternates": [],
+    "name": "graduation cap",
+    "shortname": ":mortar_board:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["cap", "college", "degree", "graduation", "hat", "school", "university", "graduation", "cap", "mortarboard", "academic", "education", "ceremony", "square", "tassel"],
+    "moji": "🎓"
+  },
+  "motorboat": {
+    "unicode": "1F6E5",
+    "unicode_alternates": [],
+    "name": "motorboat",
+    "shortname": ":motorboat:",
+    "category": "travel_places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["transportation", "vehicle", "boat", "speedboat", "powerboat"]
+  },
+  "motorcycle": {
+    "unicode": "1F3CD",
+    "unicode_alternates": [],
+    "name": "racing motorcycle",
+    "shortname": ":motorcycle:",
+    "category": "activity",
+    "aliases": [":racing_motorcycle:"],
+    "aliases_ascii": [],
+    "keywords": ["bike", "speed"]
+  },
+  "motorway": {
+    "unicode": "1F6E3",
+    "unicode_alternates": [],
+    "name": "motorway",
+    "shortname": ":motorway:",
+    "category": "travel_places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["road", "highway", "freeway", "traffic", "travel"]
+  },
+  "mount_fuji": {
+    "unicode": "1F5FB",
+    "unicode_alternates": [],
+    "name": "mount fuji",
+    "shortname": ":mount_fuji:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["japan", "mountain", "nature", "photo"],
+    "moji": "🗻"
+  },
+  "mountain_bicyclist": {
+    "unicode": "1F6B5",
+    "unicode_alternates": [],
+    "name": "mountain bicyclist",
+    "shortname": ":mountain_bicyclist:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["human", "sports", "transportation", "bicyclist", "mountain", "bike", "pedal", "bicycle", "transportation"],
+    "moji": "🚵"
+  },
+  "mountain_cableway": {
+    "unicode": "1F6A0",
+    "unicode_alternates": [],
+    "name": "mountain cableway",
+    "shortname": ":mountain_cableway:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["transportation", "vehicle", "mountain", "cable", "rail", "train", "railway"],
+    "moji": "🚠"
+  },
+  "mountain_railway": {
+    "unicode": "1F69E",
+    "unicode_alternates": [],
+    "name": "mountain railway",
+    "shortname": ":mountain_railway:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["transportation", "mountain", "railway", "rail", "train", "transport"],
+    "moji": "🚞"
+  },
+  "mountain_snow": {
+    "unicode": "1F3D4",
+    "unicode_alternates": [],
+    "name": "snow capped mountain",
+    "shortname": ":mountain_snow:",
+    "category": "travel_places",
+    "aliases": [":snow_capped_mountain:"],
+    "aliases_ascii": [],
+    "keywords": ["cold", "elevation", "hiking", "peak"]
+  },
+  "mouse": {
+    "unicode": "1F42D",
+    "unicode_alternates": [],
+    "name": "mouse face",
+    "shortname": ":mouse:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "nature"],
+    "moji": "🐭"
+  },
+  "mouse2": {
+    "unicode": "1F401",
+    "unicode_alternates": [],
+    "name": "mouse",
+    "shortname": ":mouse2:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "nature", "mouse", "mice", "rodent"],
+    "moji": "🐁"
+  },
+  "mouse_one": {
+    "unicode": "1F5AF",
+    "unicode_alternates": [],
+    "name": "one button mouse",
+    "shortname": ":mouse_one:",
+    "category": "objects_symbols",
+    "aliases": [":one_button_mouse:"],
+    "aliases_ascii": [],
+    "keywords": ["computer", "input", "device"]
+  },
+  "movie_camera": {
+    "unicode": "1F3A5",
+    "unicode_alternates": [],
+    "name": "movie camera",
+    "shortname": ":movie_camera:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["film", "record", "movie", "camera", "camcorder", "video", "motion", "picture"],
+    "moji": "🎥"
+  },
+  "moyai": {
+    "unicode": "1F5FF",
+    "unicode_alternates": [],
+    "name": "moyai",
+    "shortname": ":moyai:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["island", "stone"],
+    "moji": "🗿"
+  },
+  "muscle": {
+    "unicode": "1F4AA",
+    "unicode_alternates": [],
+    "name": "flexed biceps",
+    "shortname": ":muscle:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["arm", "flex", "hand", "strong", "muscle", "bicep"],
+    "moji": "💪"
+  },
+  "mushroom": {
+    "unicode": "1F344",
+    "unicode_alternates": [],
+    "name": "mushroom",
+    "shortname": ":mushroom:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["plant", "vegetable", "mushroom", "fungi", "food", "fungus"],
+    "moji": "🍄"
+  },
+  "musical_keyboard": {
+    "unicode": "1F3B9",
+    "unicode_alternates": [],
+    "name": "musical keyboard",
+    "shortname": ":musical_keyboard:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["instrument", "piano", "music", "keyboard", "piano", "organ", "instrument", "electric"],
+    "moji": "🎹"
+  },
+  "musical_note": {
+    "unicode": "1F3B5",
+    "unicode_alternates": [],
+    "name": "musical note",
+    "shortname": ":musical_note:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["score", "musical", "music", "note", "music", "sound"],
+    "moji": "🎵"
+  },
+  "musical_score": {
+    "unicode": "1F3BC",
+    "unicode_alternates": [],
+    "name": "musical score",
+    "shortname": ":musical_score:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["clef", "treble", "music", "musical", "score", "clef", "g-clef", "stave", "staff"],
+    "moji": "🎼"
+  },
+  "mute": {
+    "unicode": "1F507",
+    "unicode_alternates": [],
+    "name": "speaker with cancellation stroke",
+    "shortname": ":mute:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["sound", "volume"],
+    "moji": "🔇"
+  },
+  "nail_care": {
+    "unicode": "1F485",
+    "unicode_alternates": [],
+    "name": "nail polish",
+    "shortname": ":nail_care:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["beauty", "manicure"],
+    "moji": "💅"
+  },
+  "name_badge": {
+    "unicode": "1F4DB",
+    "unicode_alternates": [],
+    "name": "name badge",
+    "shortname": ":name_badge:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["fire", "forbid"],
+    "moji": "📛"
+  },
+  "necktie": {
+    "unicode": "1F454",
+    "unicode_alternates": [],
+    "name": "necktie",
+    "shortname": ":necktie:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["cloth", "fashion", "formal", "shirt", "suitup"],
+    "moji": "👔"
+  },
+  "negative_squared_cross_mark": {
+    "unicode": "274E",
+    "unicode_alternates": [],
+    "name": "negative squared cross mark",
+    "shortname": ":negative_squared_cross_mark:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["deny", "green-square", "no", "x"],
+    "moji": "❎"
+  },
+  "network": {
+    "unicode": "1F5A7",
+    "unicode_alternates": [],
+    "name": "three networked computers",
+    "shortname": ":network:",
+    "category": "objects_symbols",
+    "aliases": [":three_networked_computers:"],
+    "aliases_ascii": [],
+    "keywords": ["lan", "wan", "network", "technology"]
+  },
+  "neutral_face": {
+    "unicode": "1F610",
+    "unicode_alternates": [],
+    "name": "neutral face",
+    "shortname": ":neutral_face:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["face", "indifference", "neutral", "objective", "impartial", "blank"],
+    "moji": "😐"
+  },
+  "new": {
+    "unicode": "1F195",
+    "unicode_alternates": [],
+    "name": "squared new",
+    "shortname": ":new:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blue-square"],
+    "moji": "🆕"
+  },
+  "new_moon": {
+    "unicode": "1F311",
+    "unicode_alternates": [],
+    "name": "new moon symbol",
+    "shortname": ":new_moon:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["nature", "moon", "new", "sky", "night", "cheese", "phase"],
+    "moji": "🌑"
+  },
+  "new_moon_with_face": {
+    "unicode": "1F31A",
+    "unicode_alternates": [],
+    "name": "new moon with face",
+    "shortname": ":new_moon_with_face:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["nature", "moon", "new", "anthropomorphic", "face", "sky", "night", "cheese", "phase"],
+    "moji": "🌚"
+  },
+  "newspaper": {
+    "unicode": "1F4F0",
+    "unicode_alternates": [],
+    "name": "newspaper",
+    "shortname": ":newspaper:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["headline", "press"],
+    "moji": "📰"
+  },
+  "newspaper2": {
+    "unicode": "1F5DE",
+    "unicode_alternates": [],
+    "name": "rolled-up newspaper",
+    "shortname": ":newspaper2:",
+    "category": "objects_symbols",
+    "aliases": [":rolled_up_newspaper:"],
+    "aliases_ascii": [],
+    "keywords": ["headline", "press"]
+  },
+  "night_with_stars": {
+    "unicode": "1F303",
+    "unicode_alternates": [],
+    "name": "night with stars",
+    "shortname": ":night_with_stars:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["night", "star", "cloudless", "evening", "planets", "space", "sky"],
+    "moji": "🌃"
+  },
+  "nine": {
+    "moji": "9️⃣",
+    "unicode": "0039-20E3",
+    "unicode_alternates": ["0039-FE0F-20E3"],
+    "name": "digit nine",
+    "shortname": ":nine:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["9", "blue-square", "numbers"]
+  },
+  "no_bell": {
+    "unicode": "1F515",
+    "unicode_alternates": [],
+    "name": "bell with cancellation stroke",
+    "shortname": ":no_bell:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["mute", "sound", "volume"],
+    "moji": "🔕"
+  },
+  "no_bicycles": {
+    "unicode": "1F6B3",
+    "unicode_alternates": [],
+    "name": "no bicycles",
+    "shortname": ":no_bicycles:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["cyclist", "prohibited", "bicycle", "bike pedal", "no"],
+    "moji": "🚳"
+  },
+  "no_entry": {
+    "unicode": "26D4",
+    "unicode_alternates": ["26D4-FE0F"],
+    "name": "no entry",
+    "shortname": ":no_entry:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["bad", "denied", "limit", "privacy", "security", "stop"],
+    "moji": "â›”"
+  },
+  "no_entry_sign": {
+    "unicode": "1F6AB",
+    "unicode_alternates": [],
+    "name": "no entry sign",
+    "shortname": ":no_entry_sign:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["denied", "disallow", "forbid", "limit", "stop", "no", "stop", "entry"],
+    "moji": "🚫"
+  },
+  "no_good": {
+    "unicode": "1F645",
+    "unicode_alternates": [],
+    "name": "face with no good gesture",
+    "shortname": ":no_good:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["female", "girl", "woman", "no", "stop", "nope", "don&#039;t", "not"],
+    "moji": "🙅"
+  },
+  "no_mobile_phones": {
+    "unicode": "1F4F5",
+    "unicode_alternates": [],
+    "name": "no mobile phones",
+    "shortname": ":no_mobile_phones:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["iphone", "mute"],
+    "moji": "📵"
+  },
+  "no_mouth": {
+    "unicode": "1F636",
+    "unicode_alternates": [],
+    "name": "face without mouth",
+    "shortname": ":no_mouth:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [":-X", ":X", ":-#", ":#", "=X", "=x", ":x", ":-x", "=#"],
+    "keywords": ["face", "hellokitty", "mouth", "silent", "vapid"],
+    "moji": "😶"
+  },
+  "no_pedestrians": {
+    "unicode": "1F6B7",
+    "unicode_alternates": [],
+    "name": "no pedestrians",
+    "shortname": ":no_pedestrians:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["crossing", "rules", "walking", "no", "walk", "pedestrian", "stroll", "stride", "foot", "feet"],
+    "moji": "🚷"
+  },
+  "no_smoking": {
+    "unicode": "1F6AD",
+    "unicode_alternates": [],
+    "name": "no smoking symbol",
+    "shortname": ":no_smoking:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["cigarette", "no", "smoking", "cigarette", "smoke", "cancer", "lungs", "inhale", "tar", "nicotine"],
+    "moji": "🚭"
+  },
+  "non-potable_water": {
+    "unicode": "1F6B1",
+    "unicode_alternates": [],
+    "name": "non-potable water symbol",
+    "shortname": ":non-potable_water:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["drink", "faucet", "tap", "non-potable", "water", "not drinkable", "dirty", "gross", "aqua", "h20"],
+    "moji": "🚱"
+  },
+  "nose": {
+    "unicode": "1F443",
+    "unicode_alternates": [],
+    "name": "nose",
+    "shortname": ":nose:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["smell", "sniff"],
+    "moji": "👃"
+  },
+  "note": {
+    "unicode": "1F5C9",
+    "unicode_alternates": [],
+    "name": "note page",
+    "shortname": ":note:",
+    "category": "objects_symbols",
+    "aliases": [":note_page:"],
+    "aliases_ascii": [],
+    "keywords": ["stationery", "post-it"]
+  },
+  "note_empty": {
+    "unicode": "1F5C6",
+    "unicode_alternates": [],
+    "name": "empty note page",
+    "shortname": ":note_empty:",
+    "category": "objects_symbols",
+    "aliases": [":empty_note_page:"],
+    "aliases_ascii": [],
+    "keywords": ["stationery", "post-it"]
+  },
+  "notebook": {
+    "unicode": "1F4D3",
+    "unicode_alternates": [],
+    "name": "notebook",
+    "shortname": ":notebook:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["notes", "paper", "record", "stationery"],
+    "moji": "📓"
+  },
+  "notebook_with_decorative_cover": {
+    "unicode": "1F4D4",
+    "unicode_alternates": [],
+    "name": "notebook with decorative cover",
+    "shortname": ":notebook_with_decorative_cover:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["classroom", "notes", "paper", "record"],
+    "moji": "📔"
+  },
+  "notepad": {
+    "unicode": "1F5CA",
+    "unicode_alternates": [],
+    "name": "note pad",
+    "shortname": ":notepad:",
+    "category": "objects_symbols",
+    "aliases": [":note_pad:"],
+    "aliases_ascii": [],
+    "keywords": ["stationery", "post-it"]
+  },
+  "notepad_empty": {
+    "unicode": "1F5C7",
+    "unicode_alternates": [],
+    "name": "empty note pad",
+    "shortname": ":notepad_empty:",
+    "category": "objects_symbols",
+    "aliases": [":empty_note_pad:"],
+    "aliases_ascii": [],
+    "keywords": ["stationery", "post-it"]
+  },
+  "notepad_spiral": {
+    "unicode": "1F5D2",
+    "unicode_alternates": [],
+    "name": "spiral note pad",
+    "shortname": ":notepad_spiral:",
+    "category": "objects_symbols",
+    "aliases": [":spiral_note_pad:"],
+    "aliases_ascii": [],
+    "keywords": ["stationery"]
+  },
+  "notes": {
+    "unicode": "1F3B6",
+    "unicode_alternates": [],
+    "name": "multiple musical notes",
+    "shortname": ":notes:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["music", "score", "musical", "music", "notes", "music", "sound", "melody"],
+    "moji": "🎶"
+  },
+  "nut_and_bolt": {
+    "unicode": "1F529",
+    "unicode_alternates": [],
+    "name": "nut and bolt",
+    "shortname": ":nut_and_bolt:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["handy", "tools"],
+    "moji": "🔩"
+  },
+  "o": {
+    "unicode": "2B55",
+    "unicode_alternates": ["2B55-FE0F"],
+    "name": "heavy large circle",
+    "shortname": ":o:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["circle", "round"],
+    "moji": "â­•"
+  },
+  "o2": {
+    "unicode": "1F17E",
+    "unicode_alternates": [],
+    "name": "negative squared latin capital letter o",
+    "shortname": ":o2:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["alphabet", "letter", "red-square"],
+    "moji": "🅾"
+  },
+  "ocean": {
+    "unicode": "1F30A",
+    "unicode_alternates": [],
+    "name": "water wave",
+    "shortname": ":ocean:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["sea", "water", "wave", "ocean", "wave", "surf", "beach", "tide"],
+    "moji": "🌊"
+  },
+  "octopus": {
+    "unicode": "1F419",
+    "unicode_alternates": [],
+    "name": "octopus",
+    "shortname": ":octopus:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "creature", "ocean", "sea"],
+    "moji": "🐙"
+  },
+  "oden": {
+    "unicode": "1F362",
+    "unicode_alternates": [],
+    "name": "oden",
+    "shortname": ":oden:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["food", "japanese", "oden", "seafood", "casserole", "stew"],
+    "moji": "🍢"
+  },
+  "office": {
+    "unicode": "1F3E2",
+    "unicode_alternates": [],
+    "name": "office building",
+    "shortname": ":office:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["building", "bureau", "work"],
+    "moji": "🏢"
+  },
+  "oil": {
+    "unicode": "1F6E2",
+    "unicode_alternates": [],
+    "name": "oil drum",
+    "shortname": ":oil:",
+    "category": "objects_symbols",
+    "aliases": [":oil_drum:"],
+    "aliases_ascii": [],
+    "keywords": ["petroleum"]
+  },
+  "ok": {
+    "unicode": "1F197",
+    "unicode_alternates": [],
+    "name": "squared ok",
+    "shortname": ":ok:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["agree", "blue-square", "good", "yes"],
+    "moji": "🆗"
+  },
+  "ok_hand": {
+    "unicode": "1F44C",
+    "unicode_alternates": [],
+    "name": "ok hand sign",
+    "shortname": ":ok_hand:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["fingers", "limbs", "perfect", "okay", "ok", "smoke", "smoking", "marijuana", "joint", "pot", "420"],
+    "moji": "👌"
+  },
+  "ok_woman": {
+    "unicode": "1F646",
+    "unicode_alternates": [],
+    "name": "face with ok gesture",
+    "shortname": ":ok_woman:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": ["*\\0/*", "\\0/", "*\\O/*", "\\O/"],
+    "keywords": ["female", "girl", "human", "pink", "women", "yes", "ok", "okay", "accept"],
+    "moji": "🙆"
+  },
+  "older_man": {
+    "unicode": "1F474",
+    "unicode_alternates": [],
+    "name": "older man",
+    "shortname": ":older_man:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["human", "male", "men"],
+    "moji": "👴"
+  },
+  "older_woman": {
+    "unicode": "1F475",
+    "unicode_alternates": [],
+    "name": "older woman",
+    "shortname": ":older_woman:",
+    "category": "emoticons",
+    "aliases": [":grandma:"],
+    "aliases_ascii": [],
+    "keywords": ["female", "girl", "women", "grandma", "grandmother"],
+    "moji": "👵"
+  },
+  "om_symbol": {
+    "unicode": "1F549",
+    "unicode_alternates": [],
+    "name": "om symbol",
+    "shortname": ":om_symbol:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["hinduism", "sound", "spiritual", "icon", "dharmic", "buddhism", "jainism", "meditate"]
+  },
+  "on": {
+    "unicode": "1F51B",
+    "unicode_alternates": [],
+    "name": "on with exclamation mark with left right arrow abo",
+    "shortname": ":on:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["arrow", "words"],
+    "moji": "🔛"
+  },
+  "oncoming_automobile": {
+    "unicode": "1F698",
+    "unicode_alternates": [],
+    "name": "oncoming automobile",
+    "shortname": ":oncoming_automobile:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["car", "transportation", "vehicle", "sedan", "car", "automobile"],
+    "moji": "🚘"
+  },
+  "oncoming_bus": {
+    "unicode": "1F68D",
+    "unicode_alternates": [],
+    "name": "oncoming bus",
+    "shortname": ":oncoming_bus:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["transportation", "vehicle", "bus", "school", "city", "transportation", "public"],
+    "moji": "🚍"
+  },
+  "oncoming_police_car": {
+    "unicode": "1F694",
+    "unicode_alternates": [],
+    "name": "oncoming police car",
+    "shortname": ":oncoming_police_car:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["enforcement", "law", "vehicle", "police", "car", "emergency", "ticket", "citation", "crime", "help", "officer"],
+    "moji": "🚔"
+  },
+  "oncoming_taxi": {
+    "unicode": "1F696",
+    "unicode_alternates": [],
+    "name": "oncoming taxi",
+    "shortname": ":oncoming_taxi:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["cars", "uber", "vehicle", "taxi", "car", "automobile", "city", "transport", "service"],
+    "moji": "🚖"
+  },
+  "one": {
+    "moji": "1️⃣",
+    "unicode": "0031-20E3",
+    "unicode_alternates": ["0031-FE0F-20E3"],
+    "name": "digit one",
+    "shortname": ":one:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["1", "blue-square", "numbers"]
+  },
+  "open_file_folder": {
+    "unicode": "1F4C2",
+    "unicode_alternates": [],
+    "name": "open file folder",
+    "shortname": ":open_file_folder:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["documents", "load"],
+    "moji": "📂"
+  },
+  "open_hands": {
+    "unicode": "1F450",
+    "unicode_alternates": [],
+    "name": "open hands sign",
+    "shortname": ":open_hands:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["butterfly", "fingers"],
+    "moji": "👐"
+  },
+  "open_mouth": {
+    "unicode": "1F62E",
+    "unicode_alternates": [],
+    "name": "face with open mouth",
+    "shortname": ":open_mouth:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [":-O", ":O", ":-o", ":o", "O_O", ">:O"],
+    "keywords": ["face", "impressed", "mouth", "open", "jaw", "gapping", "surprise", "wow"],
+    "moji": "😮"
+  },
+  "ophiuchus": {
+    "unicode": "26CE",
+    "unicode_alternates": [],
+    "name": "ophiuchus",
+    "shortname": ":ophiuchus:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["ophiuchus", "serpent", "snake", "astrology", "greek", "constellation", "stars", "zodiac", "purple-square", "sign", "horoscope"],
+    "moji": "⛎"
+  },
+  "optical_disk": {
+    "unicode": "1F5B8",
+    "unicode_alternates": [],
+    "name": "optical disc icon",
+    "shortname": ":optical_disk:",
+    "category": "objects_symbols",
+    "aliases": [":optical_disc_icon:"],
+    "aliases_ascii": [],
+    "keywords": ["cd", "dvd", "disc", "disk", "technology"]
+  },
+  "orange_book": {
+    "unicode": "1F4D9",
+    "unicode_alternates": [],
+    "name": "orange book",
+    "shortname": ":orange_book:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["knowledge", "library", "read"],
+    "moji": "📙"
+  },
+  "outbox_tray": {
+    "unicode": "1F4E4",
+    "unicode_alternates": [],
+    "name": "outbox tray",
+    "shortname": ":outbox_tray:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["email", "inbox"],
+    "moji": "📤"
+  },
+  "ox": {
+    "unicode": "1F402",
+    "unicode_alternates": [],
+    "name": "ox",
+    "shortname": ":ox:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "beef", "cow"],
+    "moji": "🐂"
+  },
+  "package": {
+    "unicode": "1F4E6",
+    "unicode_alternates": [],
+    "name": "package",
+    "shortname": ":package:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["gift", "mail"],
+    "moji": "📦"
+  },
+  "page": {
+    "unicode": "1F5CF",
+    "unicode_alternates": [],
+    "name": "page",
+    "shortname": ":page:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["document"]
+  },
+  "page_facing_up": {
+    "unicode": "1F4C4",
+    "unicode_alternates": [],
+    "name": "page facing up",
+    "shortname": ":page_facing_up:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["documents"],
+    "moji": "📄"
+  },
+  "page_with_curl": {
+    "unicode": "1F4C3",
+    "unicode_alternates": [],
+    "name": "page with curl",
+    "shortname": ":page_with_curl:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["documents"],
+    "moji": "📃"
+  },
+  "pager": {
+    "unicode": "1F4DF",
+    "unicode_alternates": [],
+    "name": "pager",
+    "shortname": ":pager:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["bbcall", "oldschool"],
+    "moji": "📟"
+  },
+  "pages": {
+    "unicode": "1F5D0",
+    "unicode_alternates": [],
+    "name": "pages",
+    "shortname": ":pages:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["documents"]
+  },
+  "paintbrush": {
+    "unicode": "1F58C",
+    "unicode_alternates": [],
+    "name": "lower left paintbrush",
+    "shortname": ":paintbrush:",
+    "category": "objects_symbols",
+    "aliases": [":lower_left_paintbrush:"],
+    "aliases_ascii": [],
+    "keywords": ["brush", "art", "painting"]
+  },
+  "palm_tree": {
+    "unicode": "1F334",
+    "unicode_alternates": [],
+    "name": "palm tree",
+    "shortname": ":palm_tree:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["nature", "plant", "vegetable", "palm", "tree", "coconuts", "fronds", "warm", "tropical"],
+    "moji": "🌴"
+  },
+  "panda_face": {
+    "unicode": "1F43C",
+    "unicode_alternates": [],
+    "name": "panda face",
+    "shortname": ":panda_face:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "nature", "panda", "bear", "face", "cub", "cute", "endearment", "friendship", "love", "bamboo", "china", "black", "white"],
+    "moji": "🐼"
+  },
+  "paperclip": {
+    "unicode": "1F4CE",
+    "unicode_alternates": [],
+    "name": "paperclip",
+    "shortname": ":paperclip:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["documents", "stationery"],
+    "moji": "📎"
+  },
+  "paperclips": {
+    "unicode": "1F587",
+    "unicode_alternates": [],
+    "name": "linked paperclips",
+    "shortname": ":paperclips:",
+    "category": "objects_symbols",
+    "aliases": [":linked_paperclips:"],
+    "aliases_ascii": [],
+    "keywords": ["documents", "stationery"]
+  },
+  "park": {
+    "unicode": "1F3DE",
+    "unicode_alternates": [],
+    "name": "national park",
+    "shortname": ":park:",
+    "category": "travel_places",
+    "aliases": [":national_park:"],
+    "aliases_ascii": [],
+    "keywords": ["woods", "nature", "wildlife", "forest", "wilderness", "national"]
+  },
+  "parking": {
+    "unicode": "1F17F",
+    "unicode_alternates": ["1F17F-FE0F"],
+    "name": "negative squared latin capital letter p",
+    "shortname": ":parking:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["alphabet", "blue-square", "cars", "letter"],
+    "moji": "🅿"
+  },
+  "part_alternation_mark": {
+    "unicode": "303D",
+    "unicode_alternates": ["303D-FE0F"],
+    "name": "part alternation mark",
+    "shortname": ":part_alternation_mark:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["graph", "sing", "song", "vocal", "music", "karaoke", "cue", "letter", "m", "japanese"],
+    "moji": "〽"
+  },
+  "partly_sunny": {
+    "unicode": "26C5",
+    "unicode_alternates": ["26C5-FE0F"],
+    "name": "sun behind cloud",
+    "shortname": ":partly_sunny:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["cloud", "morning", "nature", "weather"],
+    "moji": "â›…"
+  },
+  "passport_control": {
+    "unicode": "1F6C2",
+    "unicode_alternates": [],
+    "name": "passport control",
+    "shortname": ":passport_control:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blue-square", "custom", "passport", "official", "travel", "control", "foreign", "identification"],
+    "moji": "🛂"
+  },
+  "peach": {
+    "unicode": "1F351",
+    "unicode_alternates": [],
+    "name": "peach",
+    "shortname": ":peach:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["food", "fruit", "nature", "peach", "fruit", "juicy", "pit"],
+    "moji": "🍑"
+  },
+  "pear": {
+    "unicode": "1F350",
+    "unicode_alternates": [],
+    "name": "pear",
+    "shortname": ":pear:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["fruit", "nature", "pear", "fruit", "shape"],
+    "moji": "🍐"
+  },
+  "pen_ballpoint": {
+    "unicode": "1F58A",
+    "unicode_alternates": [],
+    "name": "lower left ballpoint pen",
+    "shortname": ":pen_ballpoint:",
+    "category": "objects_symbols",
+    "aliases": [":lower_left_ballpoint_pen:"],
+    "aliases_ascii": [],
+    "keywords": ["write", "bic", "ink"]
+  },
+  "pen_fountain": {
+    "unicode": "1F58B",
+    "unicode_alternates": [],
+    "name": "lower left fountain pen",
+    "shortname": ":pen_fountain:",
+    "category": "objects_symbols",
+    "aliases": [":lower_left_fountain_pen:"],
+    "aliases_ascii": [],
+    "keywords": ["write", "calligraphy", "ink"]
+  },
+  "pencil": {
+    "unicode": "1F4DD",
+    "unicode_alternates": [],
+    "name": "memo",
+    "shortname": ":pencil:",
+    "category": "objects",
+    "aliases": [":memo:"],
+    "aliases_ascii": [],
+    "keywords": ["documents", "paper", "station", "write"],
+    "moji": "📝"
+  },
+  "pencil2": {
+    "unicode": "270F",
+    "unicode_alternates": ["270F-FE0F"],
+    "name": "pencil",
+    "shortname": ":pencil2:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["paper", "stationery", "write"],
+    "moji": "✏"
+  },
+  "pencil3": {
+    "unicode": "1F589",
+    "unicode_alternates": [],
+    "name": "lower left pencil",
+    "shortname": ":pencil3:",
+    "category": "objects_symbols",
+    "aliases": [":lower_left_pencil:"],
+    "aliases_ascii": [],
+    "keywords": ["paper", "stationery", "write"]
+  },
+  "penguin": {
+    "unicode": "1F427",
+    "unicode_alternates": [],
+    "name": "penguin",
+    "shortname": ":penguin:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "nature"],
+    "moji": "🐧"
+  },
+  "pennant_black": {
+    "unicode": "1F3F2",
+    "unicode_alternates": [],
+    "name": "black pennant",
+    "shortname": ":pennant_black:",
+    "category": "objects_symbols",
+    "aliases": [":black_pennant:"],
+    "aliases_ascii": [],
+    "keywords": ["flag", "athletics"]
+  },
+  "pennant_white": {
+    "unicode": "1F3F1",
+    "unicode_alternates": [],
+    "name": "white pennant",
+    "shortname": ":pennant_white:",
+    "category": "objects_symbols",
+    "aliases": [":white_pennant:"],
+    "aliases_ascii": [],
+    "keywords": ["flag", "athletics"]
+  },
+  "pensive": {
+    "unicode": "1F614",
+    "unicode_alternates": [],
+    "name": "pensive face",
+    "shortname": ":pensive:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["face", "okay", "sad", "pensive", "thoughtful", "think", "reflective", "wistful", "meditate", "serious"],
+    "moji": "😔"
+  },
+  "performing_arts": {
+    "unicode": "1F3AD",
+    "unicode_alternates": [],
+    "name": "performing arts",
+    "shortname": ":performing_arts:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["acting", "drama", "theater", "performing", "arts", "performance", "entertainment", "acting", "story", "mask", "masks"],
+    "moji": "🎭"
+  },
+  "persevere": {
+    "unicode": "1F623",
+    "unicode_alternates": [],
+    "name": "persevering face",
+    "shortname": ":persevere:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [">.<"],
+    "keywords": ["endure", "persevere", "face", "no", "sick", "upset"],
+    "moji": "😣"
+  },
+  "person_frowning": {
+    "unicode": "1F64D",
+    "unicode_alternates": [],
+    "name": "person frowning",
+    "shortname": ":person_frowning:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["female", "girl", "woman", "dejected", "rejected", "sad", "frown"],
+    "moji": "🙍"
+  },
+  "person_with_blond_hair": {
+    "unicode": "1F471",
+    "unicode_alternates": [],
+    "name": "person with blond hair",
+    "shortname": ":person_with_blond_hair:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["male", "man", "blonde", "young", "western", "westerner", "occidental"],
+    "moji": "👱"
+  },
+  "person_with_pouting_face": {
+    "unicode": "1F64E",
+    "unicode_alternates": [],
+    "name": "person with pouting face",
+    "shortname": ":person_with_pouting_face:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["female", "girl", "woman", "pout", "sexy", "cute", "annoyed"],
+    "moji": "🙎"
+  },
+  "pig": {
+    "unicode": "1F437",
+    "unicode_alternates": [],
+    "name": "pig face",
+    "shortname": ":pig:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "oink"],
+    "moji": "🐷"
+  },
+  "pig2": {
+    "unicode": "1F416",
+    "unicode_alternates": [],
+    "name": "pig",
+    "shortname": ":pig2:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "nature", "pig", "piggy", "pork", "ham", "hog", "bacon", "oink", "slop", "livestock", "greed", "greedy"],
+    "moji": "🐖"
+  },
+  "pig_nose": {
+    "unicode": "1F43D",
+    "unicode_alternates": [],
+    "name": "pig nose",
+    "shortname": ":pig_nose:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "oink", "pig", "nose", "snout", "food", "eat", "cute", "oink", "pink", "smell", "truffle"],
+    "moji": "🐽"
+  },
+  "pill": {
+    "unicode": "1F48A",
+    "unicode_alternates": [],
+    "name": "pill",
+    "shortname": ":pill:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["health", "medicine"],
+    "moji": "💊"
+  },
+  "pineapple": {
+    "unicode": "1F34D",
+    "unicode_alternates": [],
+    "name": "pineapple",
+    "shortname": ":pineapple:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["food", "fruit", "nature", "pineapple", "pina", "tropical", "flower"],
+    "moji": "🍍"
+  },
+  "piracy": {
+    "unicode": "1F572",
+    "unicode_alternates": [],
+    "name": "no piracy",
+    "shortname": ":piracy:",
+    "category": "objects_symbols",
+    "aliases": [":no_piracy:"],
+    "aliases_ascii": [],
+    "keywords": ["theft", "rule"]
+  },
+  "pisces": {
+    "unicode": "2653",
+    "unicode_alternates": ["2653-FE0F"],
+    "name": "pisces",
+    "shortname": ":pisces:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["pisces", "fish", "astrology", "greek", "constellation", "stars", "zodiac", "sign", "purple-square", "sign", "zodiac", "horoscope"],
+    "moji": "♓"
+  },
+  "pizza": {
+    "unicode": "1F355",
+    "unicode_alternates": [],
+    "name": "slice of pizza",
+    "shortname": ":pizza:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["food", "party", "pizza", "pie", "new york", "italian", "italy", "slice", "peperoni"],
+    "moji": "🍕"
+  },
+  "point_down": {
+    "unicode": "1F447",
+    "unicode_alternates": [],
+    "name": "white down pointing backhand index",
+    "shortname": ":point_down:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["direction", "fingers", "hand"],
+    "moji": "👇"
+  },
+  "point_left": {
+    "unicode": "1F448",
+    "unicode_alternates": [],
+    "name": "white left pointing backhand index",
+    "shortname": ":point_left:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["direction", "fingers", "hand"],
+    "moji": "👈"
+  },
+  "point_right": {
+    "unicode": "1F449",
+    "unicode_alternates": [],
+    "name": "white right pointing backhand index",
+    "shortname": ":point_right:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["direction", "fingers", "hand"],
+    "moji": "👉"
+  },
+  "point_up": {
+    "unicode": "261D",
+    "unicode_alternates": ["261D-FE0F"],
+    "name": "white up pointing index",
+    "shortname": ":point_up:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["direction", "fingers", "hand"],
+    "moji": "☝"
+  },
+  "point_up_2": {
+    "unicode": "1F446",
+    "unicode_alternates": [],
+    "name": "white up pointing backhand index",
+    "shortname": ":point_up_2:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["direction", "fingers", "hand"],
+    "moji": "👆"
+  },
+  "police_car": {
+    "unicode": "1F693",
+    "unicode_alternates": [],
+    "name": "police car",
+    "shortname": ":police_car:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["cars", "enforcement", "law", "transportation", "vehicle", "police", "car", "emergency", "ticket", "citation", "crime", "help", "officer"],
+    "moji": "🚓"
+  },
+  "poodle": {
+    "unicode": "1F429",
+    "unicode_alternates": [],
+    "name": "poodle",
+    "shortname": ":poodle:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["101", "animal", "dog", "nature", "poodle", "dog", "clip", "showy", "sophisticated", "vain"],
+    "moji": "🐩"
+  },
+  "poop": {
+    "unicode": "1F4A9",
+    "unicode_alternates": [],
+    "name": "pile of poo",
+    "shortname": ":poop:",
+    "category": "emoticons",
+    "aliases": [":shit:", ":hankey:", ":poo:"],
+    "aliases_ascii": [],
+    "keywords": ["poop", "shit", "shitface", "turd", "poo"],
+    "moji": "💩"
+  },
+  "post_office": {
+    "unicode": "1F3E3",
+    "unicode_alternates": [],
+    "name": "japanese post office",
+    "shortname": ":post_office:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["building", "communication", "email"],
+    "moji": "🏣"
+  },
+  "postal_horn": {
+    "unicode": "1F4EF",
+    "unicode_alternates": [],
+    "name": "postal horn",
+    "shortname": ":postal_horn:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["instrument", "music"],
+    "moji": "📯"
+  },
+  "postbox": {
+    "unicode": "1F4EE",
+    "unicode_alternates": [],
+    "name": "postbox",
+    "shortname": ":postbox:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["email", "envelope", "letter"],
+    "moji": "📮"
+  },
+  "potable_water": {
+    "unicode": "1F6B0",
+    "unicode_alternates": [],
+    "name": "potable water symbol",
+    "shortname": ":potable_water:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blue-square", "cleaning", "faucet", "liquid", "restroom", "potable", "water", "drinkable", "pure", "clear", "clean", "aqua", "h20"],
+    "moji": "🚰"
+  },
+  "pouch": {
+    "unicode": "1F45D",
+    "unicode_alternates": [],
+    "name": "pouch",
+    "shortname": ":pouch:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["accessories", "bag", "pouch", "bag", "cosmetic", "packing", "grandma", "makeup"],
+    "moji": "👝"
+  },
+  "poultry_leg": {
+    "unicode": "1F357",
+    "unicode_alternates": [],
+    "name": "poultry leg",
+    "shortname": ":poultry_leg:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["food", "meat", "poultry", "leg", "chicken", "fried"],
+    "moji": "🍗"
+  },
+  "pound": {
+    "unicode": "1F4B7",
+    "unicode_alternates": [],
+    "name": "banknote with pound sign",
+    "shortname": ":pound:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["bills", "british", "currency", "england", "money", "sterling", "uk", "pound", "britain", "british", "banknote", "money", "currency", "paper", "cash", "bills"],
+    "moji": "💷"
+  },
+  "pouting_cat": {
+    "unicode": "1F63E",
+    "unicode_alternates": [],
+    "name": "pouting cat face",
+    "shortname": ":pouting_cat:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "cats", "pout", "annoyed", "miffed", "glower", "frown"],
+    "moji": "😾"
+  },
+  "pray": {
+    "unicode": "1F64F",
+    "unicode_alternates": [],
+    "name": "person with folded hands",
+    "shortname": ":pray:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["highfive", "hope", "namaste", "please", "wish", "pray", "high five", "hands", "sorrow", "regret", "sorry"],
+    "moji": "🙏"
+  },
+  "princess": {
+    "unicode": "1F478",
+    "unicode_alternates": [],
+    "name": "princess",
+    "shortname": ":princess:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blond", "crown", "female", "girl", "woman", "princess", "royal", "royalty", "king", "queen", "daughter", "disney", "high-maintenance"],
+    "moji": "👸"
+  },
+  "printer": {
+    "unicode": "1F5A8",
+    "unicode_alternates": [],
+    "name": "printer",
+    "shortname": ":printer:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["hardcopy", "paper", "inkjet", "laser"]
+  },
+  "prohibited": {
+    "unicode": "1F6C7",
+    "unicode_alternates": [],
+    "name": "prohibited sign",
+    "shortname": ":prohibited:",
+    "category": "objects_symbols",
+    "aliases": [":prohibited_sign:"],
+    "aliases_ascii": [],
+    "keywords": ["no", "not", "denied", "disallow", "forbid", "limit", "stop"]
+  },
+  "projector": {
+    "unicode": "1F4FD",
+    "unicode_alternates": [],
+    "name": "film projector",
+    "shortname": ":projector:",
+    "category": "objects_symbols",
+    "aliases": [":film_projector:"],
+    "aliases_ascii": [],
+    "keywords": ["movie", "video", "motion", "picture", "8mm", "16mm"]
+  },
+  "punch": {
+    "unicode": "1F44A",
+    "unicode_alternates": [],
+    "name": "fisted hand sign",
+    "shortname": ":punch:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["fist", "hand"],
+    "moji": "👊"
+  },
+  "purple_heart": {
+    "unicode": "1F49C",
+    "unicode_alternates": [],
+    "name": "purple heart",
+    "shortname": ":purple_heart:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["affection", "like", "love", "valentines", "purple", "violet", "heart", "love", "sensitive", "understanding", "compassionate", "compassion", "duty", "honor", "royalty", "veteran", "sacrifice"],
+    "moji": "💜"
+  },
+  "purse": {
+    "unicode": "1F45B",
+    "unicode_alternates": [],
+    "name": "purse",
+    "shortname": ":purse:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["accessories", "fashion", "money", "purse", "clutch", "bag", "handbag", "coin bag", "accessory", "money", "ladies", "shopping"],
+    "moji": "👛"
+  },
+  "pushpin": {
+    "unicode": "1F4CC",
+    "unicode_alternates": [],
+    "name": "pushpin",
+    "shortname": ":pushpin:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["stationery"],
+    "moji": "📌"
+  },
+  "pushpin_black": {
+    "unicode": "1F588",
+    "unicode_alternates": [],
+    "name": "black pushpin",
+    "shortname": ":pushpin_black:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["stationery"]
+  },
+  "put_litter_in_its_place": {
+    "unicode": "1F6AE",
+    "unicode_alternates": [],
+    "name": "put litter in its place symbol",
+    "shortname": ":put_litter_in_its_place:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blue-square", "litter", "waste", "trash", "garbage", "receptacle", "can"],
+    "moji": "🚮"
+  },
+  "question": {
+    "unicode": "2753",
+    "unicode_alternates": [],
+    "name": "black question mark ornament",
+    "shortname": ":question:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["confused", "doubt"],
+    "moji": "❓"
+  },
+  "rabbit": {
+    "unicode": "1F430",
+    "unicode_alternates": [],
+    "name": "rabbit face",
+    "shortname": ":rabbit:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "nature"],
+    "moji": "🐰"
+  },
+  "rabbit2": {
+    "unicode": "1F407",
+    "unicode_alternates": [],
+    "name": "rabbit",
+    "shortname": ":rabbit2:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "nature", "rabbit", "bunny", "easter", "reproduction", "prolific"],
+    "moji": "🐇"
+  },
+  "race_car": {
+    "unicode": "1F3CE",
+    "unicode_alternates": [],
+    "name": "racing car",
+    "shortname": ":race_car:",
+    "category": "activity",
+    "aliases": [":racing_car:"],
+    "aliases_ascii": [],
+    "keywords": ["formula 1", "race", "stock", "nascar", "speed", "drive"]
+  },
+  "racehorse": {
+    "unicode": "1F40E",
+    "unicode_alternates": [],
+    "name": "horse",
+    "shortname": ":racehorse:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "gamble", "horse", "powerful", "draft", "calvary", "cowboy", "cowgirl", "mounted", "race", "ride", "gallop", "trot", "colt", "filly", "mare", "stallion", "gelding", "yearling", "thoroughbred", "pony"],
+    "moji": "🐎"
+  },
+  "radio": {
+    "unicode": "1F4FB",
+    "unicode_alternates": [],
+    "name": "radio",
+    "shortname": ":radio:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["communication", "music", "podcast", "program"],
+    "moji": "📻"
+  },
+  "radio_button": {
+    "unicode": "1F518",
+    "unicode_alternates": [],
+    "name": "radio button",
+    "shortname": ":radio_button:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["input"],
+    "moji": "🔘"
+  },
+  "rage": {
+    "unicode": "1F621",
+    "unicode_alternates": [],
+    "name": "pouting face",
+    "shortname": ":rage:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["angry", "despise", "hate", "mad", "pout", "anger", "rage", "irate"],
+    "moji": "😡"
+  },
+  "railway_car": {
+    "unicode": "1F683",
+    "unicode_alternates": [],
+    "name": "railway car",
+    "shortname": ":railway_car:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["transportation", "vehicle", "railway", "rail", "car", "coach", "train"],
+    "moji": "🚃"
+  },
+  "railway_track": {
+    "unicode": "1F6E4",
+    "unicode_alternates": [],
+    "name": "railway track",
+    "shortname": ":railway_track:",
+    "category": "travel_places",
+    "aliases": [":railroad_track:"],
+    "aliases_ascii": [],
+    "keywords": ["train", "trolley", "subway", "locomotive", "transit"]
+  },
+  "rainbow": {
+    "unicode": "1F308",
+    "unicode_alternates": [],
+    "name": "rainbow",
+    "shortname": ":rainbow:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["happy", "nature", "photo", "sky", "unicorn", "rainbow", "color", "pride", "diversity", "spectrum", "refract", "leprechaun", "gold"],
+    "moji": "🌈"
+  },
+  "raised_hand": {
+    "unicode": "270B",
+    "unicode_alternates": [],
+    "name": "raised hand",
+    "shortname": ":raised_hand:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["female", "girl", "woman"],
+    "moji": "✋"
+  },
+  "raised_hands": {
+    "unicode": "1F64C",
+    "unicode_alternates": [],
+    "name": "person raising both hands in celebration",
+    "shortname": ":raised_hands:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["gesture", "hooray", "winning", "woot", "yay", "banzai"],
+    "moji": "🙌"
+  },
+  "raising_hand": {
+    "unicode": "1F64B",
+    "unicode_alternates": [],
+    "name": "happy person raising one hand",
+    "shortname": ":raising_hand:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["female", "girl", "woman", "hand", "raise", "notice", "attention", "answer"],
+    "moji": "🙋"
+  },
+  "ram": {
+    "unicode": "1F40F",
+    "unicode_alternates": [],
+    "name": "ram",
+    "shortname": ":ram:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "nature", "sheep", "ram", "sheep", "male", "horn", "horns"],
+    "moji": "🐏"
+  },
+  "ramen": {
+    "unicode": "1F35C",
+    "unicode_alternates": [],
+    "name": "steaming bowl",
+    "shortname": ":ramen:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["chipsticks", "food", "japanese", "noodle", "ramen", "noodles", "bowl", "steaming", "soup"],
+    "moji": "🍜"
+  },
+  "rat": {
+    "unicode": "1F400",
+    "unicode_alternates": [],
+    "name": "rat",
+    "shortname": ":rat:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "mouse", "rat", "rodent", "crooked", "snitch"],
+    "moji": "🐀"
+  },
+  "recycle": {
+    "unicode": "267B",
+    "unicode_alternates": ["267B-FE0F"],
+    "name": "black universal recycling symbol",
+    "shortname": ":recycle:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["arrow", "environment", "garbage", "trash"],
+    "moji": "â™»"
+  },
+  "red_car": {
+    "unicode": "1F697",
+    "unicode_alternates": [],
+    "name": "automobile",
+    "shortname": ":red_car:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["transportation", "vehicle"],
+    "moji": "🚗"
+  },
+  "red_circle": {
+    "unicode": "1F534",
+    "unicode_alternates": [],
+    "name": "large red circle",
+    "shortname": ":red_circle:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["shape"],
+    "moji": "🔴"
+  },
+  "registered": {
+    "moji": "®",
+    "unicode": "00AE",
+    "unicode_alternates": [],
+    "name": "registered sign",
+    "shortname": ":registered:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["alphabet", "circle"]
+  },
+  "relaxed": {
+    "unicode": "263A",
+    "unicode_alternates": ["263A-FE0F"],
+    "name": "white smiling face",
+    "shortname": ":relaxed:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blush", "face", "happiness", "massage", "smile"],
+    "moji": "☺"
+  },
+  "relieved": {
+    "unicode": "1F60C",
+    "unicode_alternates": [],
+    "name": "relieved face",
+    "shortname": ":relieved:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["face", "happiness", "massage", "phew", "relaxed", "relieved", "satisfied", "phew", "relief"],
+    "moji": "😌"
+  },
+  "reminder_ribbon": {
+    "unicode": "1F397",
+    "unicode_alternates": [],
+    "name": "reminder ribbon",
+    "shortname": ":reminder_ribbon:",
+    "category": "celebration",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["awareness"]
+  },
+  "repeat": {
+    "unicode": "1F501",
+    "unicode_alternates": [],
+    "name": "clockwise rightwards and leftwards open circle arr",
+    "shortname": ":repeat:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["loop", "record"],
+    "moji": "🔁"
+  },
+  "repeat_one": {
+    "unicode": "1F502",
+    "unicode_alternates": [],
+    "name": "clockwise rightwards and leftwards open circle arr",
+    "shortname": ":repeat_one:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blue-square", "loop"],
+    "moji": "🔂"
+  },
+  "restroom": {
+    "unicode": "1F6BB",
+    "unicode_alternates": [],
+    "name": "restroom",
+    "shortname": ":restroom:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blue-square", "woman", "man", "unisex", "bathroom", "restroom", "sign", "shared", "toilet"],
+    "moji": "🚻"
+  },
+  "revolving_hearts": {
+    "unicode": "1F49E",
+    "unicode_alternates": [],
+    "name": "revolving hearts",
+    "shortname": ":revolving_hearts:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["affection", "like", "love", "valentines", "heart", "hearts", "revolving", "moving", "circle", "multiple", "lovers"],
+    "moji": "💞"
+  },
+  "rewind": {
+    "unicode": "23EA",
+    "unicode_alternates": [],
+    "name": "black left-pointing double triangle",
+    "shortname": ":rewind:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blue-square", "play"],
+    "moji": "⏪"
+  },
+  "ribbon": {
+    "unicode": "1F380",
+    "unicode_alternates": [],
+    "name": "ribbon",
+    "shortname": ":ribbon:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["bowtie", "decoration", "girl", "pink", "ribbon", "lace", "wrap", "decorate"],
+    "moji": "🎀"
+  },
+  "rice": {
+    "unicode": "1F35A",
+    "unicode_alternates": [],
+    "name": "cooked rice",
+    "shortname": ":rice:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["food", "rice", "white", "grain", "food", "bowl"],
+    "moji": "🍚"
+  },
+  "rice_ball": {
+    "unicode": "1F359",
+    "unicode_alternates": [],
+    "name": "rice ball",
+    "shortname": ":rice_ball:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["food", "japanese", "rice", "ball", "white", "nori", "seaweed", "japanese"],
+    "moji": "🍙"
+  },
+  "rice_cracker": {
+    "unicode": "1F358",
+    "unicode_alternates": [],
+    "name": "rice cracker",
+    "shortname": ":rice_cracker:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["food", "japanese", "rice", "cracker", "seaweed", "food", "japanese"],
+    "moji": "🍘"
+  },
+  "rice_scene": {
+    "unicode": "1F391",
+    "unicode_alternates": [],
+    "name": "moon viewing ceremony",
+    "shortname": ":rice_scene:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["photo", "moon", "viewing", "observing", "otsukimi", "tsukimi", "rice", "scene", "festival", "autumn"],
+    "moji": "🎑"
+  },
+  "right_speaker": {
+    "unicode": "1F568",
+    "unicode_alternates": [],
+    "name": "right speaker",
+    "shortname": ":right_speaker:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["sound", "listen", "hear", "noise", "volume"]
+  },
+  "right_speaker_one": {
+    "unicode": "1F569",
+    "unicode_alternates": [],
+    "name": "right speaker with one sound wave",
+    "shortname": ":right_speaker_one:",
+    "category": "objects_symbols",
+    "aliases": [":right_speaker_with_one_sound_wave:"],
+    "aliases_ascii": [],
+    "keywords": ["low", "volume"]
+  },
+  "right_speaker_three": {
+    "unicode": "1F56A",
+    "unicode_alternates": [],
+    "name": "right speaker with three sound waves",
+    "shortname": ":right_speaker_three:",
+    "category": "objects_symbols",
+    "aliases": [":right_speaker_with_three_sound_waves:"],
+    "aliases_ascii": [],
+    "keywords": ["loud", "high", "volume"]
+  },
+  "ring": {
+    "unicode": "1F48D",
+    "unicode_alternates": [],
+    "name": "ring",
+    "shortname": ":ring:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["marriage", "propose", "valentines", "wedding"],
+    "moji": "💍"
+  },
+  "ringing_bell": {
+    "unicode": "1F56D",
+    "unicode_alternates": [],
+    "name": "ringing bell",
+    "shortname": ":ringing_bell:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["alert", "ding", "volume", "sound", "chime"]
+  },
+  "rocket": {
+    "unicode": "1F680",
+    "unicode_alternates": [],
+    "name": "rocket",
+    "shortname": ":rocket:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["launch", "ship", "staffmode", "rocket", "space", "spacecraft", "astronaut", "cosmonaut"],
+    "moji": "🚀"
+  },
+  "roller_coaster": {
+    "unicode": "1F3A2",
+    "unicode_alternates": [],
+    "name": "roller coaster",
+    "shortname": ":roller_coaster:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["carnival", "fun", "photo", "play", "playground", "roller", "coaster", "amusement", "park", "fair", "ride", "entertainment"],
+    "moji": "🎢"
+  },
+  "rooster": {
+    "unicode": "1F413",
+    "unicode_alternates": [],
+    "name": "rooster",
+    "shortname": ":rooster:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "chicken", "nature", "rooster", "cockerel", "cock", "male", "cock-a-doodle-doo", "crowing"],
+    "moji": "🐓"
+  },
+  "rose": {
+    "unicode": "1F339",
+    "unicode_alternates": [],
+    "name": "rose",
+    "shortname": ":rose:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["flowers", "love", "valentines", "rose", "fragrant", "flower", "thorns", "love", "petals", "romance"],
+    "moji": "🌹"
+  },
+  "rosette": {
+    "unicode": "1F3F5",
+    "unicode_alternates": [],
+    "name": "rosette",
+    "shortname": ":rosette:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["flower"]
+  },
+  "rosette_black": {
+    "unicode": "1F3F6",
+    "unicode_alternates": [],
+    "name": "black rosette",
+    "shortname": ":rosette_black:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["flower"]
+  },
+  "rotating_light": {
+    "unicode": "1F6A8",
+    "unicode_alternates": [],
+    "name": "police cars revolving light",
+    "shortname": ":rotating_light:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["911", "ambulance", "emergency", "police", "light", "police", "emergency"],
+    "moji": "🚨"
+  },
+  "round_pushpin": {
+    "unicode": "1F4CD",
+    "unicode_alternates": [],
+    "name": "round pushpin",
+    "shortname": ":round_pushpin:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["stationery"],
+    "moji": "📍"
+  },
+  "rowboat": {
+    "unicode": "1F6A3",
+    "unicode_alternates": [],
+    "name": "rowboat",
+    "shortname": ":rowboat:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["hobby", "ship", "sports", "water", "boat", "row", "oar", "paddle"],
+    "moji": "🚣"
+  },
+  "rugby_football": {
+    "unicode": "1F3C9",
+    "unicode_alternates": [],
+    "name": "rugby football",
+    "shortname": ":rugby_football:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["sports", "rugby", "football", "ball", "sport", "team", "england"],
+    "moji": "🏉"
+  },
+  "runner": {
+    "unicode": "1F3C3",
+    "unicode_alternates": [],
+    "name": "runner",
+    "shortname": ":runner:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["exercise", "man", "walking", "run", "runner", "jog", "exercise", "sprint", "race", "dash"],
+    "moji": "🏃"
+  },
+  "running_shirt_with_sash": {
+    "unicode": "1F3BD",
+    "unicode_alternates": [],
+    "name": "running shirt with sash",
+    "shortname": ":running_shirt_with_sash:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["pageant", "play", "running", "run", "shirt", "cloths", "compete", "sports"],
+    "moji": "🎽"
+  },
+  "sagittarius": {
+    "unicode": "2650",
+    "unicode_alternates": ["2650-FE0F"],
+    "name": "sagittarius",
+    "shortname": ":sagittarius:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["sagittarius", "centaur", "archer", "astrology", "greek", "constellation", "stars", "zodiac", "sign", "sign", "zodiac", "horoscope"],
+    "moji": "♐"
+  },
+  "sailboat": {
+    "unicode": "26F5",
+    "unicode_alternates": ["26F5-FE0F"],
+    "name": "sailboat",
+    "shortname": ":sailboat:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["ship", "transportation"],
+    "moji": "⛵"
+  },
+  "sake": {
+    "unicode": "1F376",
+    "unicode_alternates": [],
+    "name": "sake bottle and cup",
+    "shortname": ":sake:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["beverage", "drink", "drunk", "wine", "sake", "wine", "rice", "ferment", "alcohol", "japanese", "drink"],
+    "moji": "🍶"
+  },
+  "sandal": {
+    "unicode": "1F461",
+    "unicode_alternates": [],
+    "name": "womans sandal",
+    "shortname": ":sandal:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["fashion", "shoes"],
+    "moji": "👡"
+  },
+  "santa": {
+    "unicode": "1F385",
+    "unicode_alternates": [],
+    "name": "father christmas",
+    "shortname": ":santa:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["christmas", "father christmas", "festival", "male", "man", "xmas", "santa", "saint nick", "jolly", "ho ho ho", "north pole", "presents", "gifts", "naughty", "nice", "sleigh", "father", "christmas", "holiday"],
+    "moji": "🎅"
+  },
+  "satellite": {
+    "unicode": "1F4E1",
+    "unicode_alternates": [],
+    "name": "satellite antenna",
+    "shortname": ":satellite:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["communication"],
+    "moji": "📡"
+  },
+  "satellite_orbital": {
+    "unicode": "1F6F0",
+    "unicode_alternates": [],
+    "name": "satellite",
+    "shortname": ":satellite_orbital:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["communication", "orbital", "space"]
+  },
+  "saxophone": {
+    "unicode": "1F3B7",
+    "unicode_alternates": [],
+    "name": "saxophone",
+    "shortname": ":saxophone:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["instrument", "music", "saxophone", "sax", "music", "instrument", "woodwind"],
+    "moji": "🎷"
+  },
+  "school": {
+    "unicode": "1F3EB",
+    "unicode_alternates": [],
+    "name": "school",
+    "shortname": ":school:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["building", "school", "university", "elementary", "middle", "high", "college", "teach", "education"],
+    "moji": "🏫"
+  },
+  "school_satchel": {
+    "unicode": "1F392",
+    "unicode_alternates": [],
+    "name": "school satchel",
+    "shortname": ":school_satchel:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["bag", "education", "student", "school", "satchel", "backpack", "bag", "packing", "pack", "hike", "education", "adventure", "travel", "sightsee"],
+    "moji": "🎒"
+  },
+  "scissors": {
+    "unicode": "2702",
+    "unicode_alternates": ["2702-FE0F"],
+    "name": "black scissors",
+    "shortname": ":scissors:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["cut", "stationery"],
+    "moji": "✂"
+  },
+  "scorpius": {
+    "unicode": "264F",
+    "unicode_alternates": ["264F-FE0F"],
+    "name": "scorpius",
+    "shortname": ":scorpius:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["scorpius", "scorpion", "scorpio", "astrology", "greek", "constellation", "stars", "zodiac", "sign", "sign", "zodiac", "horoscope"],
+    "moji": "♏"
+  },
+  "scream": {
+    "unicode": "1F631",
+    "unicode_alternates": [],
+    "name": "face screaming in fear",
+    "shortname": ":scream:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["face", "munch", "scream", "painting", "artist", "alien"],
+    "moji": "😱"
+  },
+  "scream_cat": {
+    "unicode": "1F640",
+    "unicode_alternates": [],
+    "name": "weary cat face",
+    "shortname": ":scream_cat:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "cats", "munch", "weary", "sleepy", "tired", "tiredness", "study", "finals", "school", "exhausted", "scream", "painting", "artist"],
+    "moji": "🙀"
+  },
+  "scroll": {
+    "unicode": "1F4DC",
+    "unicode_alternates": [],
+    "name": "scroll",
+    "shortname": ":scroll:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["documents"],
+    "moji": "📜"
+  },
+  "seat": {
+    "unicode": "1F4BA",
+    "unicode_alternates": [],
+    "name": "seat",
+    "shortname": ":seat:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["sit"],
+    "moji": "💺"
+  },
+  "secret": {
+    "unicode": "3299",
+    "unicode_alternates": ["3299-FE0F"],
+    "name": "circled ideograph secret",
+    "shortname": ":secret:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["privacy"],
+    "moji": "㊙"
+  },
+  "see_no_evil": {
+    "unicode": "1F648",
+    "unicode_alternates": [],
+    "name": "see-no-evil monkey",
+    "shortname": ":see_no_evil:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "monkey", "nature", "monkey", "see", "eyes", "vision", "sight", "mizaru"],
+    "moji": "🙈"
+  },
+  "seedling": {
+    "unicode": "1F331",
+    "unicode_alternates": [],
+    "name": "seedling",
+    "shortname": ":seedling:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["grass", "lawn", "nature", "plant", "seedling", "plant", "new", "start", "grow"],
+    "moji": "🌱"
+  },
+  "seven": {
+    "moji": "7️⃣",
+    "unicode": "0037-20E3",
+    "unicode_alternates": ["0037-FE0F-20E3"],
+    "name": "digit seven",
+    "shortname": ":seven:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["7", "blue-square", "numbers", "prime"]
+  },
+  "shaved_ice": {
+    "unicode": "1F367",
+    "unicode_alternates": [],
+    "name": "shaved ice",
+    "shortname": ":shaved_ice:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["desert", "hot", "shaved", "ice", "dessert", "treat", "syrup", "flavoring"],
+    "moji": "🍧"
+  },
+  "sheep": {
+    "unicode": "1F411",
+    "unicode_alternates": [],
+    "name": "sheep",
+    "shortname": ":sheep:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "nature", "sheep", "wool", "flock", "follower", "ewe", "female", "lamb"],
+    "moji": "🐑"
+  },
+  "shell": {
+    "unicode": "1F41A",
+    "unicode_alternates": [],
+    "name": "spiral shell",
+    "shortname": ":shell:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["beach", "nature", "sea", "shell", "spiral", "beach", "sand", "crab", "nautilus"],
+    "moji": "🐚"
+  },
+  "shield": {
+    "unicode": "1F6E1",
+    "unicode_alternates": [],
+    "name": "shield",
+    "shortname": ":shield:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["interstate", "route", "sign", "highway", "interstate"]
+  },
+  "ship": {
+    "unicode": "1F6A2",
+    "unicode_alternates": [],
+    "name": "ship",
+    "shortname": ":ship:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["titanic", "transportation", "ferry", "ship", "boat"],
+    "moji": "🚢"
+  },
+  "shirt": {
+    "unicode": "1F455",
+    "unicode_alternates": [],
+    "name": "t-shirt",
+    "shortname": ":shirt:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["cloth", "fashion"],
+    "moji": "👕"
+  },
+  "shopping_bags": {
+    "unicode": "1F6CD",
+    "unicode_alternates": [],
+    "name": "shopping bags",
+    "shortname": ":shopping_bags:",
+    "category": "travel_places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["purchase", "mall", "buy", "store", "shop"]
+  },
+  "shower": {
+    "unicode": "1F6BF",
+    "unicode_alternates": [],
+    "name": "shower",
+    "shortname": ":shower:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["bath", "clean", "wash", "bathroom", "shower", "soap", "water", "clean", "shampoo", "lather"],
+    "moji": "🚿"
+  },
+  "signal_strength": {
+    "unicode": "1F4F6",
+    "unicode_alternates": [],
+    "name": "antenna with bars",
+    "shortname": ":signal_strength:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blue-square"],
+    "moji": "📶"
+  },
+  "six": {
+    "moji": "6️⃣",
+    "unicode": "0036-20E3",
+    "unicode_alternates": ["0036-FE0F-20E3"],
+    "name": "digit six",
+    "shortname": ":six:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["6", "blue-square", "numbers"]
+  },
+  "six_pointed_star": {
+    "unicode": "1F52F",
+    "unicode_alternates": [],
+    "name": "six pointed star with middle dot",
+    "shortname": ":six_pointed_star:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["purple-square"],
+    "moji": "🔯"
+  },
+  "ski": {
+    "unicode": "1F3BF",
+    "unicode_alternates": [],
+    "name": "ski and ski boot",
+    "shortname": ":ski:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["cold", "sports", "winter", "ski", "downhill", "cross-country", "poles", "snow", "winter", "mountain", "alpine", "powder", "slalom", "freestyle"],
+    "moji": "🎿"
+  },
+  "skull": {
+    "unicode": "1F480",
+    "unicode_alternates": [],
+    "name": "skull",
+    "shortname": ":skull:",
+    "category": "emoticons",
+    "aliases": [":skeleton:"],
+    "aliases_ascii": [],
+    "keywords": ["dead", "skeleton", "dying"],
+    "moji": "💀"
+  },
+  "sleeping": {
+    "unicode": "1F634",
+    "unicode_alternates": [],
+    "name": "sleeping face",
+    "shortname": ":sleeping:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["face", "sleepy", "tired", "sleep", "sleepy", "sleeping", "snore"],
+    "moji": "😴"
+  },
+  "sleeping_accommodation": {
+    "unicode": "1F6CC",
+    "unicode_alternates": [],
+    "name": "sleeping accommodation",
+    "shortname": ":sleeping_accommodation:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["hotel", "motel", "rest"]
+  },
+  "sleepy": {
+    "unicode": "1F62A",
+    "unicode_alternates": [],
+    "name": "sleepy face",
+    "shortname": ":sleepy:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["face", "rest", "tired", "sleepy", "tired", "exhausted"],
+    "moji": "😪"
+  },
+  "slight_frown": {
+    "unicode": "1F641",
+    "unicode_alternates": [],
+    "name": "slightly frowning face",
+    "shortname": ":slight_frown:",
+    "category": "people",
+    "aliases": [":slightly_frowning_face:"],
+    "aliases_ascii": [],
+    "keywords": ["slight", "frown", "unhappy", "disappointed"]
+  },
+  "slight_smile": {
+    "unicode": "1F642",
+    "unicode_alternates": [],
+    "name": "slightly smiling face",
+    "shortname": ":slight_smile:",
+    "category": "people",
+    "aliases": [":slightly_smiling_face:"],
+    "aliases_ascii": [],
+    "keywords": ["slight", "smile", "happy"]
+  },
+  "slot_machine": {
+    "unicode": "1F3B0",
+    "unicode_alternates": [],
+    "name": "slot machine",
+    "shortname": ":slot_machine:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["bet", "gamble", "vegas", "slot", "machine", "gamble", "one-armed bandit", "slots", "luck"],
+    "moji": "🎰"
+  },
+  "small_blue_diamond": {
+    "unicode": "1F539",
+    "unicode_alternates": [],
+    "name": "small blue diamond",
+    "shortname": ":small_blue_diamond:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["shape"],
+    "moji": "🔹"
+  },
+  "small_orange_diamond": {
+    "unicode": "1F538",
+    "unicode_alternates": [],
+    "name": "small orange diamond",
+    "shortname": ":small_orange_diamond:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["shape"],
+    "moji": "🔸"
+  },
+  "small_red_triangle": {
+    "unicode": "1F53A",
+    "unicode_alternates": [],
+    "name": "up-pointing red triangle",
+    "shortname": ":small_red_triangle:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["shape"],
+    "moji": "🔺"
+  },
+  "small_red_triangle_down": {
+    "unicode": "1F53B",
+    "unicode_alternates": [],
+    "name": "down-pointing red triangle",
+    "shortname": ":small_red_triangle_down:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["shape"],
+    "moji": "🔻"
+  },
+  "smile": {
+    "unicode": "1F604",
+    "unicode_alternates": [],
+    "name": "smiling face with open mouth and smiling eyes",
+    "shortname": ":smile:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [":)", ":-)", "=]", "=)", ":]"],
+    "keywords": ["face", "funny", "haha", "happy", "joy", "laugh", "smile", "smiley", "smiling"],
+    "moji": "😄"
+  },
+  "smile_cat": {
+    "unicode": "1F638",
+    "unicode_alternates": [],
+    "name": "grinning cat face with smiling eyes",
+    "shortname": ":smile_cat:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "cats", "cat", "smile", "grin", "grinning"],
+    "moji": "😸"
+  },
+  "smiley": {
+    "unicode": "1F603",
+    "unicode_alternates": [],
+    "name": "smiling face with open mouth",
+    "shortname": ":smiley:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [":D", ":-D", "=D"],
+    "keywords": ["face", "haha", "happy", "joy", "smiling", "smile", "smiley"],
+    "moji": "😃"
+  },
+  "smiley_cat": {
+    "unicode": "1F63A",
+    "unicode_alternates": [],
+    "name": "smiling cat face with open mouth",
+    "shortname": ":smiley_cat:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "cats", "happy", "smile", "smiley", "cat", "happy"],
+    "moji": "😺"
+  },
+  "smiling_imp": {
+    "unicode": "1F608",
+    "unicode_alternates": [],
+    "name": "smiling face with horns",
+    "shortname": ":smiling_imp:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["devil", "horns", "horns", "devil", "impish", "trouble"],
+    "moji": "😈"
+  },
+  "smirk": {
+    "unicode": "1F60F",
+    "unicode_alternates": [],
+    "name": "smirking face",
+    "shortname": ":smirk:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["mean", "prank", "smile", "smug", "smirking", "smirk", "smug", "smile", "half-smile", "conceited"],
+    "moji": "😏"
+  },
+  "smirk_cat": {
+    "unicode": "1F63C",
+    "unicode_alternates": [],
+    "name": "cat face with wry smile",
+    "shortname": ":smirk_cat:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "cats", "smirk", "smirking", "wry", "confident", "confidence"],
+    "moji": "😼"
+  },
+  "smoking": {
+    "unicode": "1F6AC",
+    "unicode_alternates": [],
+    "name": "smoking symbol",
+    "shortname": ":smoking:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["cigarette", "kills", "tobacco", "smoking", "cigarette", "smoke", "cancer", "lungs", "inhale", "tar", "nicotine"],
+    "moji": "🚬"
+  },
+  "snail": {
+    "unicode": "1F40C",
+    "unicode_alternates": [],
+    "name": "snail",
+    "shortname": ":snail:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "shell", "slow", "snail", "slow", "escargot", "french", "appetizer"],
+    "moji": "🐌"
+  },
+  "snake": {
+    "unicode": "1F40D",
+    "unicode_alternates": [],
+    "name": "snake",
+    "shortname": ":snake:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "evil"],
+    "moji": "🐍"
+  },
+  "snowboarder": {
+    "unicode": "1F3C2",
+    "unicode_alternates": [],
+    "name": "snowboarder",
+    "shortname": ":snowboarder:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["sports", "winter", "snow", "boarding", "sports", "freestyle", "halfpipe", "board", "mountain", "alpine", "winter"],
+    "moji": "🏂"
+  },
+  "snowflake": {
+    "unicode": "2744",
+    "unicode_alternates": ["2744-FE0F"],
+    "name": "snowflake",
+    "shortname": ":snowflake:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["christmas", "cold", "season", "weather", "winter", "xmas", "snowflake", "snow", "frozen", "droplet", "ice", "crystal", "cold", "chilly", "winter", "unique", "special", "below zero", "elsa"],
+    "moji": "❄"
+  },
+  "snowman": {
+    "unicode": "26C4",
+    "unicode_alternates": ["26C4-FE0F"],
+    "name": "snowman without snow",
+    "shortname": ":snowman:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["christmas", "cold", "season", "weather", "winter", "xmas"],
+    "moji": "⛄"
+  },
+  "sob": {
+    "unicode": "1F62D",
+    "unicode_alternates": [],
+    "name": "loudly crying face",
+    "shortname": ":sob:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["cry", "face", "sad", "tears", "upset", "cry", "sob", "tears", "sad", "melancholy", "morn", "somber", "hurt"],
+    "moji": "😭"
+  },
+  "soccer": {
+    "unicode": "26BD",
+    "unicode_alternates": ["26BD-FE0F"],
+    "name": "soccer ball",
+    "shortname": ":soccer:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["balls", "fifa", "football", "sports", "european", "football"],
+    "moji": "âš½"
+  },
+  "soon": {
+    "unicode": "1F51C",
+    "unicode_alternates": [],
+    "name": "soon with rightwards arrow above",
+    "shortname": ":soon:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["arrow", "words"],
+    "moji": "🔜"
+  },
+  "sos": {
+    "unicode": "1F198",
+    "unicode_alternates": [],
+    "name": "squared sos",
+    "shortname": ":sos:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["emergency", "help", "red-square", "words"],
+    "moji": "🆘"
+  },
+  "sound": {
+    "unicode": "1F509",
+    "unicode_alternates": [],
+    "name": "speaker with one sound wave",
+    "shortname": ":sound:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["speaker", "volume"],
+    "moji": "🔉"
+  },
+  "space_invader": {
+    "unicode": "1F47E",
+    "unicode_alternates": [],
+    "name": "alien monster",
+    "shortname": ":space_invader:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["arcade", "game"],
+    "moji": "👾"
+  },
+  "spades": {
+    "unicode": "2660",
+    "unicode_alternates": ["2660-FE0F"],
+    "name": "black spade suit",
+    "shortname": ":spades:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["cards", "poker"],
+    "moji": "â™ "
+  },
+  "spaghetti": {
+    "unicode": "1F35D",
+    "unicode_alternates": [],
+    "name": "spaghetti",
+    "shortname": ":spaghetti:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["food", "italian", "noodle", "spaghetti", "noodles", "tomato", "sauce", "italian"],
+    "moji": "🍝"
+  },
+  "sparkle": {
+    "unicode": "2747",
+    "unicode_alternates": ["2747-FE0F"],
+    "name": "sparkle",
+    "shortname": ":sparkle:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["green-square", "stars"],
+    "moji": "❇"
+  },
+  "sparkler": {
+    "unicode": "1F387",
+    "unicode_alternates": [],
+    "name": "firework sparkler",
+    "shortname": ":sparkler:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["night", "shine", "stars"],
+    "moji": "🎇"
+  },
+  "sparkles": {
+    "unicode": "2728",
+    "unicode_alternates": [],
+    "name": "sparkles",
+    "shortname": ":sparkles:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["cool", "shine", "shiny", "stars"],
+    "moji": "✨"
+  },
+  "sparkling_heart": {
+    "unicode": "1F496",
+    "unicode_alternates": [],
+    "name": "sparkling heart",
+    "shortname": ":sparkling_heart:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["affection", "like", "love", "valentines"],
+    "moji": "💖"
+  },
+  "speak_no_evil": {
+    "unicode": "1F64A",
+    "unicode_alternates": [],
+    "name": "speak-no-evil monkey",
+    "shortname": ":speak_no_evil:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "monkey", "monkey", "mouth", "talk", "say", "words", "verbal", "verbalize", "oral", "iwazaru"],
+    "moji": "🙊"
+  },
+  "speaker": {
+    "unicode": "1F508",
+    "unicode_alternates": [],
+    "name": "speaker",
+    "shortname": ":speaker:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["sound", "listen", "hear", "noise"]
+  },
+  "speaking_head": {
+    "unicode": "1F5E3",
+    "unicode_alternates": [],
+    "name": "speaking head in silhouette",
+    "shortname": ":speaking_head:",
+    "category": "objects_symbols",
+    "aliases": [":speaking_head_in_silhouette:"],
+    "aliases_ascii": [],
+    "keywords": ["talk"]
+  },
+  "speech_balloon": {
+    "unicode": "1F4AC",
+    "unicode_alternates": [],
+    "name": "speech balloon",
+    "shortname": ":speech_balloon:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["bubble", "words", "speech", "balloon", "talk", "conversation", "communication", "comic", "dialogue"],
+    "moji": "💬"
+  },
+  "speech_left": {
+    "unicode": "1F5E8",
+    "unicode_alternates": [],
+    "name": "left speech bubble",
+    "shortname": ":speech_left:",
+    "category": "objects_symbols",
+    "aliases": [":left_speech_bubble:"],
+    "aliases_ascii": [],
+    "keywords": ["balloon", "words", "talk", "conversation", "communication", "comic", "dialogue"]
+  },
+  "speech_right": {
+    "unicode": "1F5E9",
+    "unicode_alternates": [],
+    "name": "right speech bubble",
+    "shortname": ":speech_right:",
+    "category": "objects_symbols",
+    "aliases": [":right_speech_bubble:"],
+    "aliases_ascii": [],
+    "keywords": ["balloon", "words", "talk", "conversation", "communication", "comic", "dialogue"]
+  },
+  "speech_three": {
+    "unicode": "1F5EB",
+    "unicode_alternates": [],
+    "name": "three speech bubbles",
+    "shortname": ":speech_three:",
+    "category": "objects_symbols",
+    "aliases": [":three_speech_bubbles:"],
+    "aliases_ascii": [],
+    "keywords": ["balloon", "words", "talk", "conversation", "communication", "comic", "dialogue"]
+  },
+  "speech_two": {
+    "unicode": "1F5EA",
+    "unicode_alternates": [],
+    "name": "two speech bubbles",
+    "shortname": ":speech_two:",
+    "category": "objects_symbols",
+    "aliases": [":two_speech_bubbles:"],
+    "aliases_ascii": [],
+    "keywords": ["balloon", "words", "talk", "conversation", "communication", "comic", "dialogue"]
+  },
+  "speedboat": {
+    "unicode": "1F6A4",
+    "unicode_alternates": [],
+    "name": "speedboat",
+    "shortname": ":speedboat:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["ship", "transportation", "vehicle", "motor", "speed", "ski", "power", "boat"],
+    "moji": "🚤"
+  },
+  "spider": {
+    "unicode": "1F577",
+    "unicode_alternates": [],
+    "name": "spider",
+    "shortname": ":spider:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["arachnid", "eight-legged"]
+  },
+  "spider_web": {
+    "unicode": "1F578",
+    "unicode_alternates": [],
+    "name": "spider web",
+    "shortname": ":spider_web:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["cobweb"]
+  },
+  "spy": {
+    "unicode": "1F575",
+    "unicode_alternates": [],
+    "name": "sleuth or spy",
+    "shortname": ":spy:",
+    "category": "people",
+    "aliases": [":sleuth_or_spy:"],
+    "aliases_ascii": [],
+    "keywords": ["pi", "undercover", "investigator"]
+  },
+  "stadium": {
+    "unicode": "1F3DF",
+    "unicode_alternates": [],
+    "name": "stadium",
+    "shortname": ":stadium:",
+    "category": "travel_places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["sport", "event", "concert", "convention", "game"]
+  },
+  "star": {
+    "unicode": "2B50",
+    "unicode_alternates": ["2B50-FE0F"],
+    "name": "white medium star",
+    "shortname": ":star:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["night", "yellow"],
+    "moji": "⭐"
+  },
+  "star2": {
+    "unicode": "1F31F",
+    "unicode_alternates": [],
+    "name": "glowing star",
+    "shortname": ":star2:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["night", "sparkle", "glow", "glowing", "star", "five", "points", "classic"],
+    "moji": "🌟"
+  },
+  "stars": {
+    "unicode": "1F320",
+    "unicode_alternates": [],
+    "name": "shooting star",
+    "shortname": ":stars:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["night", "photo", "shooting", "shoot", "star", "sky", "night", "comet", "meteoroid"],
+    "moji": "🌠"
+  },
+  "station": {
+    "unicode": "1F689",
+    "unicode_alternates": [],
+    "name": "station",
+    "shortname": ":station:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["public", "transportation", "vehicle", "station", "train", "subway"],
+    "moji": "🚉"
+  },
+  "statue_of_liberty": {
+    "unicode": "1F5FD",
+    "unicode_alternates": [],
+    "name": "statue of liberty",
+    "shortname": ":statue_of_liberty:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["american", "newyork"],
+    "moji": "🗽"
+  },
+  "steam_locomotive": {
+    "unicode": "1F682",
+    "unicode_alternates": [],
+    "name": "steam locomotive",
+    "shortname": ":steam_locomotive:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["train", "transportation", "vehicle", "locomotive", "steam", "train", "engine"],
+    "moji": "🚂"
+  },
+  "stereo": {
+    "unicode": "1F4FE",
+    "unicode_alternates": [],
+    "name": "portable stereo",
+    "shortname": ":stereo:",
+    "category": "objects_symbols",
+    "aliases": [":portable_stereo:"],
+    "aliases_ascii": [],
+    "keywords": ["communication", "music", "program", "boom", "box"]
+  },
+  "stew": {
+    "unicode": "1F372",
+    "unicode_alternates": [],
+    "name": "pot of food",
+    "shortname": ":stew:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["food", "meat", "stew", "hearty", "soup", "thick", "hot", "pot"],
+    "moji": "🍲"
+  },
+  "stock_chart": {
+    "unicode": "1F5E0",
+    "unicode_alternates": [],
+    "name": "stock chart",
+    "shortname": ":stock_chart:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["graph", "presentation", "stats", "business"]
+  },
+  "straight_ruler": {
+    "unicode": "1F4CF",
+    "unicode_alternates": [],
+    "name": "straight ruler",
+    "shortname": ":straight_ruler:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["stationery"],
+    "moji": "📏"
+  },
+  "strawberry": {
+    "unicode": "1F353",
+    "unicode_alternates": [],
+    "name": "strawberry",
+    "shortname": ":strawberry:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["food", "fruit", "nature", "strawberry", "short", "cake", "berry"],
+    "moji": "🍓"
+  },
+  "stuck_out_tongue": {
+    "unicode": "1F61B",
+    "unicode_alternates": [],
+    "name": "face with stuck-out tongue",
+    "shortname": ":stuck_out_tongue:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [":P", ":-P", "=P", ":-p", ":p", "=p", ":-Þ", ":Þ", ":þ", ":-þ", ":-b", ":b", "d:"],
+    "keywords": ["childish", "face", "mischievous", "playful", "prank", "tongue", "silly", "playful", "cheeky"],
+    "moji": "😛"
+  },
+  "stuck_out_tongue_closed_eyes": {
+    "unicode": "1F61D",
+    "unicode_alternates": [],
+    "name": "face with stuck-out tongue and tightly-closed eyes",
+    "shortname": ":stuck_out_tongue_closed_eyes:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["face", "mischievous", "playful", "prank", "tongue", "kidding", "silly", "playful", "ecstatic"],
+    "moji": "😝"
+  },
+  "stuck_out_tongue_winking_eye": {
+    "unicode": "1F61C",
+    "unicode_alternates": [],
+    "name": "face with stuck-out tongue and winking eye",
+    "shortname": ":stuck_out_tongue_winking_eye:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [">:P", "X-P", "x-p"],
+    "keywords": ["childish", "face", "mischievous", "playful", "prank", "tongue", "wink", "winking", "kidding", "silly", "playful", "crazy"],
+    "moji": "😜"
+  },
+  "sun_with_face": {
+    "unicode": "1F31E",
+    "unicode_alternates": [],
+    "name": "sun with face",
+    "shortname": ":sun_with_face:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["morning", "sun", "anthropomorphic", "face", "sky"],
+    "moji": "🌞"
+  },
+  "sunflower": {
+    "unicode": "1F33B",
+    "unicode_alternates": [],
+    "name": "sunflower",
+    "shortname": ":sunflower:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["nature", "plant", "sunflower", "sun", "flower", "seeds", "yellow"],
+    "moji": "🌻"
+  },
+  "sunglasses": {
+    "unicode": "1F60E",
+    "unicode_alternates": [],
+    "name": "smiling face with sunglasses",
+    "shortname": ":sunglasses:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": ["B-)", "B)", "8)", "8-)", "B-D", "8-D"],
+    "keywords": ["cool", "face", "smiling", "sunglasses", "sun", "glasses", "sunny", "cool", "smooth"],
+    "moji": "😎"
+  },
+  "sunny": {
+    "unicode": "2600",
+    "unicode_alternates": ["2600-FE0F"],
+    "name": "black sun with rays",
+    "shortname": ":sunny:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["brightness", "weather"]
+  },
+  "sunrise": {
+    "unicode": "1F305",
+    "unicode_alternates": [],
+    "name": "sunrise",
+    "shortname": ":sunrise:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["morning", "photo", "vacation", "view", "sunrise", "sun", "morning", "color", "sky"],
+    "moji": "🌅"
+  },
+  "sunrise_over_mountains": {
+    "unicode": "1F304",
+    "unicode_alternates": [],
+    "name": "sunrise over mountains",
+    "shortname": ":sunrise_over_mountains:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["photo", "vacation", "view", "sunrise", "sun", "morning", "mountain", "rural", "color", "sky"],
+    "moji": "🌄"
+  },
+  "surfer": {
+    "unicode": "1F3C4",
+    "unicode_alternates": [],
+    "name": "surfer",
+    "shortname": ":surfer:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["ocean", "sea", "sports", "surfer", "surf", "wave", "ocean", "ride", "swell"],
+    "moji": "🏄"
+  },
+  "sushi": {
+    "unicode": "1F363",
+    "unicode_alternates": [],
+    "name": "sushi",
+    "shortname": ":sushi:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["food", "japanese", "sushi", "fish", "raw", "nigiri", "japanese"],
+    "moji": "🍣"
+  },
+  "suspension_railway": {
+    "unicode": "1F69F",
+    "unicode_alternates": [],
+    "name": "suspension railway",
+    "shortname": ":suspension_railway:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["transportation", "vehicle", "suspension", "railway", "rail", "train", "transportation"],
+    "moji": "🚟"
+  },
+  "sweat": {
+    "unicode": "1F613",
+    "unicode_alternates": [],
+    "name": "face with cold sweat",
+    "shortname": ":sweat:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": ["':(", "':-(", "'=("],
+    "keywords": ["cold", "sweat", "sick", "anxious", "worried", "clammy", "diaphoresis", "face", "hot"],
+    "moji": "😓"
+  },
+  "sweat_drops": {
+    "unicode": "1F4A6",
+    "unicode_alternates": [],
+    "name": "splashing sweat symbol",
+    "shortname": ":sweat_drops:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["water"],
+    "moji": "💦"
+  },
+  "sweat_smile": {
+    "unicode": "1F605",
+    "unicode_alternates": [],
+    "name": "smiling face with open mouth and cold sweat",
+    "shortname": ":sweat_smile:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": ["':)", "':-)", "'=)", "':D", "':-D", "'=D"],
+    "keywords": ["face", "happy", "hot", "smiling", "cold", "sweat", "perspiration"],
+    "moji": "😅"
+  },
+  "sweet_potato": {
+    "unicode": "1F360",
+    "unicode_alternates": [],
+    "name": "roasted sweet potato",
+    "shortname": ":sweet_potato:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["food", "nature", "sweet", "potato", "potassium", "roasted", "roast"],
+    "moji": "🍠"
+  },
+  "swimmer": {
+    "unicode": "1F3CA",
+    "unicode_alternates": [],
+    "name": "swimmer",
+    "shortname": ":swimmer:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["sports", "swimmer", "swim", "water", "pool", "laps", "freestyle", "butterfly", "breaststroke", "backstroke"],
+    "moji": "🏊"
+  },
+  "symbols": {
+    "unicode": "1F523",
+    "unicode_alternates": [],
+    "name": "input symbol for symbols",
+    "shortname": ":symbols:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blue-square"],
+    "moji": "🔣"
+  },
+  "syringe": {
+    "unicode": "1F489",
+    "unicode_alternates": [],
+    "name": "syringe",
+    "shortname": ":syringe:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blood", "drugs", "health", "hospital", "medicine", "needle"],
+    "moji": "💉"
+  },
+  "tada": {
+    "unicode": "1F389",
+    "unicode_alternates": [],
+    "name": "party popper",
+    "shortname": ":tada:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["contulations", "party", "party", "popper", "tada", "celebration", "victory", "announcement", "climax", "congratulations"],
+    "moji": "🎉"
+  },
+  "tanabata_tree": {
+    "unicode": "1F38B",
+    "unicode_alternates": [],
+    "name": "tanabata tree",
+    "shortname": ":tanabata_tree:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["nature", "plant", "tanabata", "tree", "festival", "star", "wish", "holiday"],
+    "moji": "🎋"
+  },
+  "tangerine": {
+    "unicode": "1F34A",
+    "unicode_alternates": [],
+    "name": "tangerine",
+    "shortname": ":tangerine:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["food", "fruit", "nature", "tangerine", "citrus", "orange"],
+    "moji": "🍊"
+  },
+  "taurus": {
+    "unicode": "2649",
+    "unicode_alternates": ["2649-FE0F"],
+    "name": "taurus",
+    "shortname": ":taurus:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["purple-square", "sign", "taurus", "bull", "astrology", "greek", "constellation", "stars", "zodiac", "sign", "zodiac", "horoscope"],
+    "moji": "♉"
+  },
+  "taxi": {
+    "unicode": "1F695",
+    "unicode_alternates": [],
+    "name": "taxi",
+    "shortname": ":taxi:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["cars", "transportation", "uber", "vehicle", "taxi", "car", "automobile", "city", "transport", "service"],
+    "moji": "🚕"
+  },
+  "tea": {
+    "unicode": "1F375",
+    "unicode_alternates": [],
+    "name": "teacup without handle",
+    "shortname": ":tea:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["bowl", "breakfast", "british", "drink", "green", "tea", "leaf", "drink", "teacup", "hot", "beverage"],
+    "moji": "🍵"
+  },
+  "telephone": {
+    "unicode": "260E",
+    "unicode_alternates": ["260E-FE0F"],
+    "name": "black telephone",
+    "shortname": ":telephone:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["communication", "dial", "technology"],
+    "moji": "☎"
+  },
+  "telephone_black": {
+    "unicode": "1F57F",
+    "unicode_alternates": [],
+    "name": "black touchtone telephone",
+    "shortname": ":telephone_black:",
+    "category": "objects_symbols",
+    "aliases": [":black_touchtone_telephone:"],
+    "aliases_ascii": [],
+    "keywords": ["communication", "dial", "technology"]
+  },
+  "telephone_receiver": {
+    "unicode": "1F4DE",
+    "unicode_alternates": [],
+    "name": "telephone receiver",
+    "shortname": ":telephone_receiver:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["communication", "dial", "technology"],
+    "moji": "📞"
+  },
+  "telephone_white": {
+    "unicode": "1F57E",
+    "unicode_alternates": [],
+    "name": "white touchtone telephone",
+    "shortname": ":telephone_white:",
+    "category": "objects_symbols",
+    "aliases": [":white_touchtone_telephone:"],
+    "aliases_ascii": [],
+    "keywords": ["communication", "dial", "technology"]
+  },
+  "telescope": {
+    "unicode": "1F52D",
+    "unicode_alternates": [],
+    "name": "telescope",
+    "shortname": ":telescope:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["space", "stars"],
+    "moji": "🔭"
+  },
+  "tennis": {
+    "unicode": "1F3BE",
+    "unicode_alternates": [],
+    "name": "tennis racquet and ball",
+    "shortname": ":tennis:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["balls", "green", "sports", "tennis", "racket", "racquet", "ball", "game", "net", "court", "love"],
+    "moji": "🎾"
+  },
+  "tent": {
+    "unicode": "26FA",
+    "unicode_alternates": ["26FA-FE0F"],
+    "name": "tent",
+    "shortname": ":tent:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["camp", "outdoors", "photo"],
+    "moji": "⛺"
+  },
+  "thermometer": {
+    "unicode": "1F321",
+    "unicode_alternates": [],
+    "name": "thermometer",
+    "shortname": ":thermometer:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["temperature"]
+  },
+  "thought_balloon": {
+    "unicode": "1F4AD",
+    "unicode_alternates": [],
+    "name": "thought balloon",
+    "shortname": ":thought_balloon:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["bubble", "cloud", "speech", "thought", "balloon", "comic", "think", "day dream", "wonder"],
+    "moji": "💭"
+  },
+  "thought_left": {
+    "unicode": "1F5EC",
+    "unicode_alternates": [],
+    "name": "left thought bubble",
+    "shortname": ":thought_left:",
+    "category": "objects_symbols",
+    "aliases": [":left_thought_bubble:"],
+    "aliases_ascii": [],
+    "keywords": ["balloon", "cloud", "comic", "think", "day dream", "wonder"]
+  },
+  "thought_right": {
+    "unicode": "1F5ED",
+    "unicode_alternates": [],
+    "name": "right thought bubble",
+    "shortname": ":thought_right:",
+    "category": "objects_symbols",
+    "aliases": [":right_thought_bubble:"],
+    "aliases_ascii": [],
+    "keywords": ["balloon", "cloud", "comic", "think", "day dream", "wonder"]
+  },
+  "three": {
+    "moji": "3️⃣",
+    "unicode": "0033-20E3",
+    "unicode_alternates": ["0033-FE0F-20E3"],
+    "name": "digit three",
+    "shortname": ":three:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["3", "blue-square", "numbers", "prime"]
+  },
+  "thumbs_down_reverse": {
+    "unicode": "1F593",
+    "unicode_alternates": [],
+    "name": "reversed thumbs down sign",
+    "shortname": ":thumbs_down_reverse:",
+    "category": "people",
+    "aliases": [":reversed_thumbs_down_sign:"],
+    "aliases_ascii": [],
+    "keywords": ["hand", "no", "-1"]
+  },
+  "thumbs_up_reverse": {
+    "unicode": "1F592",
+    "unicode_alternates": [],
+    "name": "reversed thumbs up sign",
+    "shortname": ":thumbs_up_reverse:",
+    "category": "people",
+    "aliases": [":reversed_thumbs_up_sign:"],
+    "aliases_ascii": [],
+    "keywords": ["cool", "hand", "like", "yes", "+1"]
+  },
+  "thumbsdown": {
+    "unicode": "1F44E",
+    "unicode_alternates": [],
+    "name": "thumbs down sign",
+    "shortname": ":thumbsdown:",
+    "category": "emoticons",
+    "aliases": [":-1:"],
+    "aliases_ascii": [],
+    "keywords": ["hand", "no"],
+    "moji": "👎"
+  },
+  "thumbsup": {
+    "unicode": "1F44D",
+    "unicode_alternates": [],
+    "name": "thumbs up sign",
+    "shortname": ":thumbsup:",
+    "category": "emoticons",
+    "aliases": [":+1:"],
+    "aliases_ascii": [],
+    "keywords": ["cool", "hand", "like", "yes"],
+    "moji": "👍"
+  },
+  "ticket": {
+    "unicode": "1F3AB",
+    "unicode_alternates": [],
+    "name": "ticket",
+    "shortname": ":ticket:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["concert", "event", "pass", "ticket", "show", "entertainment", "stub", "admission", "proof", "purchase"],
+    "moji": "🎫"
+  },
+  "tickets": {
+    "unicode": "1F39F",
+    "unicode_alternates": [],
+    "name": "admission tickets",
+    "shortname": ":tickets:",
+    "category": "activity",
+    "aliases": [":admission_tickets:"],
+    "aliases_ascii": [],
+    "keywords": ["concert", "event", "pass", "show", "entertainment", "stub", "proof", "purchase"]
+  },
+  "tiger": {
+    "unicode": "1F42F",
+    "unicode_alternates": [],
+    "name": "tiger face",
+    "shortname": ":tiger:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal"],
+    "moji": "🐯"
+  },
+  "tiger2": {
+    "unicode": "1F405",
+    "unicode_alternates": [],
+    "name": "tiger",
+    "shortname": ":tiger2:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "nature", "tiger", "cat", "striped", "tony", "tigger", "hobs"],
+    "moji": "🐅"
+  },
+  "tired_face": {
+    "unicode": "1F62B",
+    "unicode_alternates": [],
+    "name": "tired face",
+    "shortname": ":tired_face:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["face", "frustrated", "sick", "upset", "whine", "exhausted", "sleepy", "tired"],
+    "moji": "😫"
+  },
+  "toilet": {
+    "unicode": "1F6BD",
+    "unicode_alternates": [],
+    "name": "toilet",
+    "shortname": ":toilet:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["restroom", "wc", "toilet", "bathroom", "throne", "porcelain", "waste", "flush", "plumbing"],
+    "moji": "🚽"
+  },
+  "tokyo_tower": {
+    "unicode": "1F5FC",
+    "unicode_alternates": [],
+    "name": "tokyo tower",
+    "shortname": ":tokyo_tower:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["japan", "photo"],
+    "moji": "🗼"
+  },
+  "tomato": {
+    "unicode": "1F345",
+    "unicode_alternates": [],
+    "name": "tomato",
+    "shortname": ":tomato:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["food", "fruit", "nature", "vegetable", "tomato", "fruit", "sauce", "italian"],
+    "moji": "🍅"
+  },
+  "tongue": {
+    "unicode": "1F445",
+    "unicode_alternates": [],
+    "name": "tongue",
+    "shortname": ":tongue:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["mouth", "playful", "tongue", "mouth", "taste", "buds", "food", "silly", "playful", "tease", "kiss", "french kiss", "lick", "tasty", "playfulness", "silliness", "intimacy"],
+    "moji": "👅"
+  },
+  "tools": {
+    "unicode": "1F6E0",
+    "unicode_alternates": [],
+    "name": "hammer and wrench",
+    "shortname": ":tools:",
+    "category": "objects_symbols",
+    "aliases": [":hammer_and_wrench:"],
+    "aliases_ascii": [],
+    "keywords": ["tools"]
+  },
+  "top": {
+    "unicode": "1F51D",
+    "unicode_alternates": [],
+    "name": "top with upwards arrow above",
+    "shortname": ":top:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blue-square", "words"],
+    "moji": "🔝"
+  },
+  "tophat": {
+    "unicode": "1F3A9",
+    "unicode_alternates": [],
+    "name": "top hat",
+    "shortname": ":tophat:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["classy", "gentleman", "magic", "top", "hat", "cap", "beaver", "high", "tall", "stove", "pipe", "chimney", "topper", "london", "period piece", "magic", "magician"],
+    "moji": "🎩"
+  },
+  "trackball": {
+    "unicode": "1F5B2",
+    "unicode_alternates": [],
+    "name": "trackball",
+    "shortname": ":trackball:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["input", "device", "gadget"]
+  },
+  "tractor": {
+    "unicode": "1F69C",
+    "unicode_alternates": [],
+    "name": "tractor",
+    "shortname": ":tractor:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["agriculture", "car", "farming", "vehicle", "tractor", "farm", "construction", "machine", "digger"],
+    "moji": "🚜"
+  },
+  "traffic_light": {
+    "unicode": "1F6A5",
+    "unicode_alternates": [],
+    "name": "horizontal traffic light",
+    "shortname": ":traffic_light:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["traffic", "transportation", "traffic", "light", "stop", "go", "yield", "horizontal"],
+    "moji": "🚥"
+  },
+  "train": {
+    "unicode": "1F68B",
+    "unicode_alternates": [],
+    "name": "Tram Car",
+    "shortname": ":train:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["tram", "rail"]
+  },
+  "train2": {
+    "unicode": "1F686",
+    "unicode_alternates": [],
+    "name": "train",
+    "shortname": ":train2:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["transportation", "vehicle", "train", "locomotive", "rail"],
+    "moji": "🚆"
+  },
+  "train_diesel": {
+    "unicode": "1F6F2",
+    "unicode_alternates": [],
+    "name": "diesel locomotive",
+    "shortname": ":train_diesel:",
+    "category": "travel_places",
+    "aliases": [":diesel_locomotive:"],
+    "aliases_ascii": [],
+    "keywords": ["train", "transportation", "engine", "rail"]
+  },
+  "tram": {
+    "unicode": "1F68A",
+    "unicode_alternates": [],
+    "name": "tram",
+    "shortname": ":tram:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["transportation", "vehicle", "tram", "transportation", "transport"],
+    "moji": "🚊"
+  },
+  "triangle_round": {
+    "unicode": "1F6C6",
+    "unicode_alternates": [],
+    "name": "triangle with rounded corners",
+    "shortname": ":triangle_round:",
+    "category": "objects_symbols",
+    "aliases": [":triangle_with_rounded_corners:"],
+    "aliases_ascii": [],
+    "keywords": ["caution", "warning", "alert"]
+  },
+  "triangular_flag_on_post": {
+    "unicode": "1F6A9",
+    "unicode_alternates": [],
+    "name": "triangular flag on post",
+    "shortname": ":triangular_flag_on_post:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["triangle", "triangular", "flag", "golf", "post", "flagpole"],
+    "moji": "🚩"
+  },
+  "triangular_ruler": {
+    "unicode": "1F4D0",
+    "unicode_alternates": [],
+    "name": "triangular ruler",
+    "shortname": ":triangular_ruler:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["architect", "math", "sketch", "stationery"],
+    "moji": "📐"
+  },
+  "trident": {
+    "unicode": "1F531",
+    "unicode_alternates": [],
+    "name": "trident emblem",
+    "shortname": ":trident:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["spear", "weapon"],
+    "moji": "🔱"
+  },
+  "triumph": {
+    "unicode": "1F624",
+    "unicode_alternates": [],
+    "name": "face with look of triumph",
+    "shortname": ":triumph:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["face", "gas", "phew", "triumph", "steam", "breath"],
+    "moji": "😤"
+  },
+  "trolleybus": {
+    "unicode": "1F68E",
+    "unicode_alternates": [],
+    "name": "trolleybus",
+    "shortname": ":trolleybus:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["bart", "transportation", "vehicle", "trolley", "bus", "city", "transport", "transportation"],
+    "moji": "🚎"
+  },
+  "trophy": {
+    "unicode": "1F3C6",
+    "unicode_alternates": [],
+    "name": "trophy",
+    "shortname": ":trophy:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["award", "ceremony", "contest", "ftw", "place", "win", "trophy", "first", "show", "place", "win", "reward", "achievement", "medal"],
+    "moji": "🏆"
+  },
+  "tropical_drink": {
+    "unicode": "1F379",
+    "unicode_alternates": [],
+    "name": "tropical drink",
+    "shortname": ":tropical_drink:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["beverage", "tropical", "drink", "mixed", "pineapple", "coconut", "pina", "fruit", "umbrella"],
+    "moji": "🍹"
+  },
+  "tropical_fish": {
+    "unicode": "1F420",
+    "unicode_alternates": [],
+    "name": "tropical fish",
+    "shortname": ":tropical_fish:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "swim"],
+    "moji": "🐠"
+  },
+  "truck": {
+    "unicode": "1F69A",
+    "unicode_alternates": [],
+    "name": "delivery truck",
+    "shortname": ":truck:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["cars", "transportation", "truck", "delivery", "package"],
+    "moji": "🚚"
+  },
+  "trumpet": {
+    "unicode": "1F3BA",
+    "unicode_alternates": [],
+    "name": "trumpet",
+    "shortname": ":trumpet:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["brass", "music", "trumpet", "brass", "music", "instrument"],
+    "moji": "🎺"
+  },
+  "tulip": {
+    "unicode": "1F337",
+    "unicode_alternates": [],
+    "name": "tulip",
+    "shortname": ":tulip:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["flowers", "nature", "plant", "tulip", "flower", "bulb", "spring", "easter"],
+    "moji": "🌷"
+  },
+  "turned_ok_hand": {
+    "unicode": "1F58F",
+    "unicode_alternates": [],
+    "name": "turned ok hand sign",
+    "shortname": ":turned_ok_hand:",
+    "category": "people",
+    "aliases": [":turned_ok_hand_sign:"],
+    "aliases_ascii": [],
+    "keywords": ["perfect", "okay"]
+  },
+  "turtle": {
+    "unicode": "1F422",
+    "unicode_alternates": [],
+    "name": "turtle",
+    "shortname": ":turtle:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "slow", "turtle", "shell", "tortoise", "chelonian", "reptile", "slow", "snap", "steady"],
+    "moji": "🐢"
+  },
+  "twisted_rightwards_arrows": {
+    "unicode": "1F500",
+    "unicode_alternates": [],
+    "name": "twisted rightwards arrows",
+    "shortname": ":twisted_rightwards_arrows:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blue-square"],
+    "moji": "🔀"
+  },
+  "two": {
+    "moji": "2️⃣",
+    "unicode": "0032-20E3",
+    "unicode_alternates": ["0032-FE0F-20E3"],
+    "name": "digit two",
+    "shortname": ":two:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["2", "blue-square", "numbers", "prime"]
+  },
+  "two_hearts": {
+    "unicode": "1F495",
+    "unicode_alternates": [],
+    "name": "two hearts",
+    "shortname": ":two_hearts:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["affection", "like", "love", "valentines", "heart", "hearts", "two", "love", "emotion"],
+    "moji": "💕"
+  },
+  "two_men_holding_hands": {
+    "unicode": "1F46C",
+    "unicode_alternates": [],
+    "name": "two men holding hands",
+    "shortname": ":two_men_holding_hands:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["bromance", "couple", "friends", "like", "love", "men", "gay", "homosexual", "friends", "hands", "holding", "team", "unity"],
+    "moji": "👬"
+  },
+  "two_women_holding_hands": {
+    "unicode": "1F46D",
+    "unicode_alternates": [],
+    "name": "two women holding hands",
+    "shortname": ":two_women_holding_hands:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["couple", "female", "friends", "like", "love", "women", "hands", "girlfriends", "friends", "sisters", "mother", "daughter", "gay", "homosexual", "couple", "unity"],
+    "moji": "👭"
+  },
+  "u5272": {
+    "unicode": "1F239",
+    "unicode_alternates": [],
+    "name": "squared cjk unified ideograph-5272",
+    "shortname": ":u5272:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["chinese", "cut", "divide", "kanji", "pink"],
+    "moji": "🈹"
+  },
+  "u5408": {
+    "unicode": "1F234",
+    "unicode_alternates": [],
+    "name": "squared cjk unified ideograph-5408",
+    "shortname": ":u5408:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["chinese", "japanese", "join", "kanji"],
+    "moji": "🈴"
+  },
+  "u55b6": {
+    "unicode": "1F23A",
+    "unicode_alternates": [],
+    "name": "squared cjk unified ideograph-55b6",
+    "shortname": ":u55b6:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["japanese", "opening hours"],
+    "moji": "🈺"
+  },
+  "u6307": {
+    "unicode": "1F22F",
+    "unicode_alternates": ["1F22F-FE0F"],
+    "name": "squared cjk unified ideograph-6307",
+    "shortname": ":u6307:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["chinese", "green-square", "kanji", "point"],
+    "moji": "🈯"
+  },
+  "u6708": {
+    "unicode": "1F237",
+    "unicode_alternates": [],
+    "name": "squared cjk unified ideograph-6708",
+    "shortname": ":u6708:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["chinese", "japanese", "kanji", "moon", "orange-square"],
+    "moji": "🈷"
+  },
+  "u6709": {
+    "unicode": "1F236",
+    "unicode_alternates": [],
+    "name": "squared cjk unified ideograph-6709",
+    "shortname": ":u6709:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["chinese", "have", "kanji", "orange-square"],
+    "moji": "🈶"
+  },
+  "u6e80": {
+    "unicode": "1F235",
+    "unicode_alternates": [],
+    "name": "squared cjk unified ideograph-6e80",
+    "shortname": ":u6e80:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["chinese", "full", "japanese", "kanji", "red-square"],
+    "moji": "🈵"
+  },
+  "u7121": {
+    "unicode": "1F21A",
+    "unicode_alternates": ["1F21A-FE0F"],
+    "name": "squared cjk unified ideograph-7121",
+    "shortname": ":u7121:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["chinese", "japanese", "kanji", "no", "nothing", "orange-square"],
+    "moji": "🈚"
+  },
+  "u7533": {
+    "unicode": "1F238",
+    "unicode_alternates": [],
+    "name": "squared cjk unified ideograph-7533",
+    "shortname": ":u7533:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["chinese", "japanese", "kanji"],
+    "moji": "🈸"
+  },
+  "u7981": {
+    "unicode": "1F232",
+    "unicode_alternates": [],
+    "name": "squared cjk unified ideograph-7981",
+    "shortname": ":u7981:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["chinese", "forbidden", "japanese", "kanji", "limit", "restricted"],
+    "moji": "🈲"
+  },
+  "u7a7a": {
+    "unicode": "1F233",
+    "unicode_alternates": [],
+    "name": "squared cjk unified ideograph-7a7a",
+    "shortname": ":u7a7a:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["chinese", "empty", "japanese", "kanji"],
+    "moji": "🈳"
+  },
+  "umbrella": {
+    "unicode": "2614",
+    "unicode_alternates": ["2614-FE0F"],
+    "name": "umbrella with rain drops",
+    "shortname": ":umbrella:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["rain", "weather"],
+    "moji": "☔"
+  },
+  "unamused": {
+    "unicode": "1F612",
+    "unicode_alternates": [],
+    "name": "unamused face",
+    "shortname": ":unamused:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["bored", "face", "indifference", "serious", "straight face", "unamused", "not amused", "depressed", "unhappy", "disapprove", "lame"],
+    "moji": "😒"
+  },
+  "underage": {
+    "unicode": "1F51E",
+    "unicode_alternates": [],
+    "name": "no one under eighteen symbol",
+    "shortname": ":underage:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["18", "drink", "night", "pub"],
+    "moji": "🔞"
+  },
+  "unlock": {
+    "unicode": "1F513",
+    "unicode_alternates": [],
+    "name": "open lock",
+    "shortname": ":unlock:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["privacy", "security"],
+    "moji": "🔓"
+  },
+  "up": {
+    "unicode": "1F199",
+    "unicode_alternates": [],
+    "name": "squared up with exclamation mark",
+    "shortname": ":up:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blue-square"],
+    "moji": "🆙"
+  },
+  "v": {
+    "unicode": "270C",
+    "unicode_alternates": ["270C-FE0F"],
+    "name": "victory hand",
+    "shortname": ":v:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["fingers", "hand", "ohyeah", "peace", "two", "victory"],
+    "moji": "✌"
+  },
+  "vertical_traffic_light": {
+    "unicode": "1F6A6",
+    "unicode_alternates": [],
+    "name": "vertical traffic light",
+    "shortname": ":vertical_traffic_light:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["transportation", "traffic", "light", "stop", "go", "yield", "vertical"],
+    "moji": "🚦"
+  },
+  "vhs": {
+    "unicode": "1F4FC",
+    "unicode_alternates": [],
+    "name": "videocassette",
+    "shortname": ":vhs:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["oldschool", "record", "video"],
+    "moji": "📼"
+  },
+  "vibration_mode": {
+    "unicode": "1F4F3",
+    "unicode_alternates": [],
+    "name": "vibration mode",
+    "shortname": ":vibration_mode:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["orange-square", "phone"],
+    "moji": "📳"
+  },
+  "video_camera": {
+    "unicode": "1F4F9",
+    "unicode_alternates": [],
+    "name": "video camera",
+    "shortname": ":video_camera:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["film", "record"],
+    "moji": "📹"
+  },
+  "video_game": {
+    "unicode": "1F3AE",
+    "unicode_alternates": [],
+    "name": "video game",
+    "shortname": ":video_game:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["PS4", "console", "controller", "play", "video", "game", "console", "controller", "nintendo", "xbox", "playstation"],
+    "moji": "🎮"
+  },
+  "violin": {
+    "unicode": "1F3BB",
+    "unicode_alternates": [],
+    "name": "violin",
+    "shortname": ":violin:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["instrument", "music", "violin", "fiddle", "music", "instrument"],
+    "moji": "🎻"
+  },
+  "virgo": {
+    "unicode": "264D",
+    "unicode_alternates": ["264D-FE0F"],
+    "name": "virgo",
+    "shortname": ":virgo:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["sign", "virgo", "maiden", "astrology", "greek", "constellation", "stars", "zodiac", "sign", "zodiac", "horoscope"],
+    "moji": "♍"
+  },
+  "volcano": {
+    "unicode": "1F30B",
+    "unicode_alternates": [],
+    "name": "volcano",
+    "shortname": ":volcano:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["nature", "photo", "volcano", "lava", "magma", "hot", "explode"],
+    "moji": "🌋"
+  },
+  "vs": {
+    "unicode": "1F19A",
+    "unicode_alternates": [],
+    "name": "squared vs",
+    "shortname": ":vs:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["orange-square", "words"],
+    "moji": "🆚"
+  },
+  "vulcan": {
+    "unicode": "1F596",
+    "unicode_alternates": [],
+    "name": "raised hand with part between middle and ring fingers",
+    "shortname": ":vulcan:",
+    "category": "people",
+    "aliases": [":raised_hand_with_part_between_middle_and_ring_fingers:"],
+    "aliases_ascii": [],
+    "keywords": ["vulcan", "spock", "leonard", "nimoy", "star trek", "live long"]
+  },
+  "walking": {
+    "unicode": "1F6B6",
+    "unicode_alternates": [],
+    "name": "pedestrian",
+    "shortname": ":walking:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["human", "man", "walk", "pedestrian", "stroll", "stride", "foot", "feet"],
+    "moji": "🚶"
+  },
+  "waning_crescent_moon": {
+    "unicode": "1F318",
+    "unicode_alternates": [],
+    "name": "waning crescent moon symbol",
+    "shortname": ":waning_crescent_moon:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["nature", "moon", "crescent", "waning", "sky", "night", "cheese", "phase"],
+    "moji": "🌘"
+  },
+  "waning_gibbous_moon": {
+    "unicode": "1F316",
+    "unicode_alternates": [],
+    "name": "waning gibbous moon symbol",
+    "shortname": ":waning_gibbous_moon:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["nature", "moon", "waning", "gibbous", "sky", "night", "cheese", "phase"],
+    "moji": "🌖"
+  },
+  "warning": {
+    "unicode": "26A0",
+    "unicode_alternates": ["26A0-FE0F"],
+    "name": "warning sign",
+    "shortname": ":warning:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["exclamation", "wip"],
+    "moji": "âš "
+  },
+  "wastebasket": {
+    "unicode": "1F5D1",
+    "unicode_alternates": [],
+    "name": "wastebasket",
+    "shortname": ":wastebasket:",
+    "category": "objects_symbols",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["trash", "garbage", "dispose"]
+  },
+  "watch": {
+    "unicode": "231A",
+    "unicode_alternates": ["231A-FE0F"],
+    "name": "watch",
+    "shortname": ":watch:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["accessories", "time"],
+    "moji": "⌚"
+  },
+  "water_buffalo": {
+    "unicode": "1F403",
+    "unicode_alternates": [],
+    "name": "water buffalo",
+    "shortname": ":water_buffalo:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "cow", "nature", "ox", "water", "buffalo", "asia", "bovine", "milk", "dairy"],
+    "moji": "🐃"
+  },
+  "watermelon": {
+    "unicode": "1F349",
+    "unicode_alternates": [],
+    "name": "watermelon",
+    "shortname": ":watermelon:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["food", "fruit", "melon", "watermelon", "summer", "fruit", "large"],
+    "moji": "🍉"
+  },
+  "wave": {
+    "unicode": "1F44B",
+    "unicode_alternates": [],
+    "name": "waving hand sign",
+    "shortname": ":wave:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["farewell", "gesture", "goodbye", "hands", "solong"],
+    "moji": "👋"
+  },
+  "wavy_dash": {
+    "unicode": "3030",
+    "unicode_alternates": [],
+    "name": "wavy dash",
+    "shortname": ":wavy_dash:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["draw", "line"],
+    "moji": "〰"
+  },
+  "waxing_crescent_moon": {
+    "unicode": "1F312",
+    "unicode_alternates": [],
+    "name": "waxing crescent moon symbol",
+    "shortname": ":waxing_crescent_moon:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["nature", "moon", "waxing", "sky", "night", "cheese", "phase"],
+    "moji": "🌒"
+  },
+  "waxing_gibbous_moon": {
+    "unicode": "1F314",
+    "unicode_alternates": [],
+    "name": "waxing gibbous moon symbol",
+    "shortname": ":waxing_gibbous_moon:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["nature"],
+    "moji": "🌔"
+  },
+  "wc": {
+    "unicode": "1F6BE",
+    "unicode_alternates": [],
+    "name": "water closet",
+    "shortname": ":wc:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blue-square", "restroom", "toilet", "water", "closet", "toilet", "bathroom", "throne", "porcelain", "waste", "flush", "plumbing"],
+    "moji": "🚾"
+  },
+  "weary": {
+    "unicode": "1F629",
+    "unicode_alternates": [],
+    "name": "weary face",
+    "shortname": ":weary:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["face", "frustrated", "sad", "sleepy", "tired", "weary", "sleepy", "tired", "tiredness", "study", "finals", "school", "exhausted"],
+    "moji": "😩"
+  },
+  "wedding": {
+    "unicode": "1F492",
+    "unicode_alternates": [],
+    "name": "wedding",
+    "shortname": ":wedding:",
+    "category": "places",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["affection", "bride", "couple", "groom", "like", "love", "marriage"],
+    "moji": "💒"
+  },
+  "whale": {
+    "unicode": "1F433",
+    "unicode_alternates": [],
+    "name": "spouting whale",
+    "shortname": ":whale:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "nature", "ocean", "sea"],
+    "moji": "🐳"
+  },
+  "whale2": {
+    "unicode": "1F40B",
+    "unicode_alternates": [],
+    "name": "whale",
+    "shortname": ":whale2:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "nature", "ocean", "sea", "whale", "blubber", "bloated", "fat", "large", "massive"],
+    "moji": "🐋"
+  },
+  "wheelchair": {
+    "unicode": "267F",
+    "unicode_alternates": ["267F-FE0F"],
+    "name": "wheelchair symbol",
+    "shortname": ":wheelchair:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blue-square", "disabled"],
+    "moji": "♿"
+  },
+  "white_check_mark": {
+    "unicode": "2705",
+    "unicode_alternates": [],
+    "name": "white heavy check mark",
+    "shortname": ":white_check_mark:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["agree", "green-square", "ok"],
+    "moji": "✅"
+  },
+  "white_circle": {
+    "unicode": "26AA",
+    "unicode_alternates": ["26AA-FE0F"],
+    "name": "medium white circle",
+    "shortname": ":white_circle:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["shape"],
+    "moji": "⚪"
+  },
+  "white_flower": {
+    "unicode": "1F4AE",
+    "unicode_alternates": [],
+    "name": "white flower",
+    "shortname": ":white_flower:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["japanese", "white", "flower", "teacher", "school", "grade", "score", "brilliance", "intelligence", "homework", "student", "assignment", "praise"],
+    "moji": "💮"
+  },
+  "white_large_square": {
+    "unicode": "2B1C",
+    "unicode_alternates": ["2B1C-FE0F"],
+    "name": "white large square",
+    "shortname": ":white_large_square:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["shape"],
+    "moji": "⬜"
+  },
+  "white_medium_small_square": {
+    "unicode": "25FD",
+    "unicode_alternates": ["25FD-FE0F"],
+    "name": "white medium small square",
+    "shortname": ":white_medium_small_square:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["shape"],
+    "moji": "â—½"
+  },
+  "white_medium_square": {
+    "unicode": "25FB",
+    "unicode_alternates": ["25FB-FE0F"],
+    "name": "white medium square",
+    "shortname": ":white_medium_square:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["shape"],
+    "moji": "â—»"
+  },
+  "white_small_square": {
+    "unicode": "25AB",
+    "unicode_alternates": ["25AB-FE0F"],
+    "name": "white small square",
+    "shortname": ":white_small_square:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["shape"],
+    "moji": "â–«"
+  },
+  "white_square_button": {
+    "unicode": "1F533",
+    "unicode_alternates": [],
+    "name": "white square button",
+    "shortname": ":white_square_button:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["shape"],
+    "moji": "🔳"
+  },
+  "wind_blowing_face": {
+    "unicode": "1F32C",
+    "unicode_alternates": [],
+    "name": "wind blowing face",
+    "shortname": ":wind_blowing_face:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["mother", "nature"]
+  },
+  "wind_chime": {
+    "unicode": "1F390",
+    "unicode_alternates": [],
+    "name": "wind chime",
+    "shortname": ":wind_chime:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["ding", "nature", "wind", "chime", "bell", "fūrin", "instrument", "music", "spirits", "soothing", "protective", "spiritual", "sound"],
+    "moji": "🎐"
+  },
+  "wine_glass": {
+    "unicode": "1F377",
+    "unicode_alternates": [],
+    "name": "wine glass",
+    "shortname": ":wine_glass:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["alcohol", "beverage", "booze", "bottle", "drink", "drunk", "fermented", "glass", "grapes", "tasting", "wine", "winery"],
+    "moji": "🍷"
+  },
+  "wink": {
+    "unicode": "1F609",
+    "unicode_alternates": [],
+    "name": "winking face",
+    "shortname": ":wink:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [";)", ";-)", "*-)", "*)", ";-]", ";]", ";D", ";^)"],
+    "keywords": ["face", "happy", "mischievous", "secret", "wink", "winking", "friendly", "joke"],
+    "moji": "😉"
+  },
+  "wolf": {
+    "unicode": "1F43A",
+    "unicode_alternates": [],
+    "name": "wolf face",
+    "shortname": ":wolf:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["animal", "nature"],
+    "moji": "🐺"
+  },
+  "woman": {
+    "unicode": "1F469",
+    "unicode_alternates": [],
+    "name": "woman",
+    "shortname": ":woman:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["female", "girls"],
+    "moji": "👩"
+  },
+  "womans_clothes": {
+    "unicode": "1F45A",
+    "unicode_alternates": [],
+    "name": "womans clothes",
+    "shortname": ":womans_clothes:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["fashion", "woman", "clothing", "clothes", "blouse", "shirt", "wardrobe", "breasts", "cleavage", "shopping", "shop", "dressing", "dressed"],
+    "moji": "👚"
+  },
+  "womans_hat": {
+    "unicode": "1F452",
+    "unicode_alternates": [],
+    "name": "womans hat",
+    "shortname": ":womans_hat:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["accessories", "fashion", "female"],
+    "moji": "👒"
+  },
+  "womens": {
+    "unicode": "1F6BA",
+    "unicode_alternates": [],
+    "name": "womens symbol",
+    "shortname": ":womens:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["purple-square", "woman", "bathroom", "restroom", "sign", "girl", "female", "avatar"],
+    "moji": "🚺"
+  },
+  "worried": {
+    "unicode": "1F61F",
+    "unicode_alternates": [],
+    "name": "worried face",
+    "shortname": ":worried:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["concern", "face", "nervous", "worried", "anxious", "distressed", "nervous", "tense"],
+    "moji": "😟"
+  },
+  "wrench": {
+    "unicode": "1F527",
+    "unicode_alternates": [],
+    "name": "wrench",
+    "shortname": ":wrench:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["diy", "ikea", "tools"],
+    "moji": "🔧"
+  },
+  "writing_hand": {
+    "unicode": "1F58E",
+    "unicode_alternates": [],
+    "name": "left writing hand",
+    "shortname": ":writing_hand:",
+    "category": "people",
+    "aliases": [":left_writing_hand:"],
+    "aliases_ascii": [],
+    "keywords": ["write", "sign", "signature", "draw"]
+  },
+  "x": {
+    "unicode": "274C",
+    "unicode_alternates": [],
+    "name": "cross mark",
+    "shortname": ":x:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["delete", "no", "remove"],
+    "moji": "❌"
+  },
+  "yellow_heart": {
+    "unicode": "1F49B",
+    "unicode_alternates": [],
+    "name": "yellow heart",
+    "shortname": ":yellow_heart:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["affection", "like", "love", "valentines", "yellow", "gold", "heart", "love", "friendship", "happy", "happiness", "trust", "compassionate", "respectful", "honest", "caring", "selfless"],
+    "moji": "💛"
+  },
+  "yen": {
+    "unicode": "1F4B4",
+    "unicode_alternates": [],
+    "name": "banknote with yen sign",
+    "shortname": ":yen:",
+    "category": "objects",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["currency", "dollar", "japanese", "money", "yen", "japan", "japanese", "banknote", "money", "currency", "paper", "cash", "bill"],
+    "moji": "💴"
+  },
+  "yum": {
+    "unicode": "1F60B",
+    "unicode_alternates": [],
+    "name": "face savouring delicious food",
+    "shortname": ":yum:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["face", "happy", "joy", "smile", "tongue", "delicious", "savoring", "food", "eat", "yummy", "yum", "tasty", "savory"],
+    "moji": "😋"
+  },
+  "zap": {
+    "unicode": "26A1",
+    "unicode_alternates": ["26A1-FE0F"],
+    "name": "high voltage sign",
+    "shortname": ":zap:",
+    "category": "nature",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["lightning bolt", "thunder", "weather"],
+    "moji": "âš¡"
+  },
+  "zero": {
+    "moji": "0️⃣",
+    "unicode": "0030-20E3",
+    "unicode_alternates": ["0030-FE0F-20E3"],
+    "name": "digit zero",
+    "shortname": ":zero:",
+    "category": "other",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["blue-square", "null", "numbers"]
+  },
+  "zzz": {
+    "unicode": "1F4A4",
+    "unicode_alternates": [],
+    "name": "sleeping symbol",
+    "shortname": ":zzz:",
+    "category": "emoticons",
+    "aliases": [],
+    "aliases_ascii": [],
+    "keywords": ["sleepy", "tired"],
+    "moji": "💤"
+  }
+}
diff --git a/lib/api/files.rb b/lib/api/files.rb
index a7a768f8895ded69e5bfeba3c9e38819af79e6d6..8ad2c1883c77e7b91ee86026f5217264585eb235 100644
--- a/lib/api/files.rb
+++ b/lib/api/files.rb
@@ -7,7 +7,7 @@ module API
       def commit_params(attrs)
         {
           file_path: attrs[:file_path],
-          current_branch: attrs[:branch_name],
+          source_branch: attrs[:branch_name],
           target_branch: attrs[:branch_name],
           commit_message: attrs[:commit_message],
           file_content: attrs[:content],
diff --git a/lib/api/projects.rb b/lib/api/projects.rb
index 5e75cd35c56c6945eddb65c461d8050a3d0b4100..a9e0960872a08cb1b455a448b8458364acd95e8d 100644
--- a/lib/api/projects.rb
+++ b/lib/api/projects.rb
@@ -25,7 +25,7 @@ module API
         @projects = current_user.authorized_projects
         @projects = filter_projects(@projects)
         @projects = paginate @projects
-        present @projects, with: Entities::Project
+        present @projects, with: Entities::ProjectWithAccess, user: current_user
       end
 
       # Get an owned projects list for authenticated user
@@ -36,7 +36,7 @@ module API
         @projects = current_user.owned_projects
         @projects = filter_projects(@projects)
         @projects = paginate @projects
-        present @projects, with: Entities::Project
+        present @projects, with: Entities::ProjectWithAccess, user: current_user
       end
 
       # Gets starred project for the authenticated user
@@ -59,7 +59,7 @@ module API
         @projects = Project.all
         @projects = filter_projects(@projects)
         @projects = paginate @projects
-        present @projects, with: Entities::Project
+        present @projects, with: Entities::ProjectWithAccess, user: current_user
       end
 
       # Get a single project
diff --git a/lib/award_emoji.rb b/lib/award_emoji.rb
index 4d99164bc3319e8fc1dc241627d8735da93d1115..783fcfb61ad0363326eac5abff1970e1de318814 100644
--- a/lib/award_emoji.rb
+++ b/lib/award_emoji.rb
@@ -1,47 +1,51 @@
 class AwardEmoji
-  EMOJI_LIST = [
-    "+1", "-1", "100", "blush", "heart", "smile", "rage",
-    "beers", "disappointed", "ok_hand",
-    "helicopter", "shit", "airplane", "alarm_clock",
-    "ambulance", "anguished", "two_hearts", "wink"
-  ]
-
-  ALIASES = {
-    pout: "rage",
-    satisfied: "laughing",
-    hankey: "shit",
-    poop: "shit",
-    collision: "boom",
-    thumbsup: "+1",
-    thumbsdown: "-1",
-    punch: "facepunch",
-    raised_hand: "hand",
-    running: "runner",
-    ng_woman: "no_good",
-    shoe: "mans_shoe",
-    tshirt: "shirt",
-    honeybee: "bee",
-    flipper: "dolphin",
-    paw_prints: "feet",
-    waxing_gibbous_moon: "moon",
-    telephone: "phone",
-    knife: "hocho",
-    envelope: "email",
-    pencil: "memo",
-    open_book: "book",
-    sailboat: "boat",
-    red_car: "car",
-    lantern: "izakaya_lantern",
-    uk: "gb",
-    heavy_exclamation_mark: "exclamation",
-    squirrel: "shipit"
+  CATEGORIES = {
+    other: "Other",
+    objects: "Objects",
+    places: "Places",
+    travel_places: "Travel",
+    emoticons: "Emoticons",
+    objects_symbols: "Symbols",
+    nature: "Nature",
+    celebration: "Celebration",
+    people: "People",
+    activity: "Activity",
+    flags: "Flags",
+    food_drink: "Food"
   }.with_indifferent_access
 
-  def self.path_to_emoji_image(name)
-    "emoji/#{Emoji.emoji_filename(name)}.png"
+  def self.normilize_emoji_name(name)
+    aliases[name] || name
   end
 
-  def self.normilize_emoji_name(name)
-    ALIASES[name] || name
+  def self.emoji_by_category
+    unless @emoji_by_category
+      @emoji_by_category = {}
+
+      emojis.each do |emoji_name, data|
+        data["name"] = emoji_name
+
+        @emoji_by_category[data["category"]] ||= []
+        @emoji_by_category[data["category"]] << data
+      end
+
+      @emoji_by_category = @emoji_by_category.sort.to_h
+    end
+
+    @emoji_by_category
+  end
+
+  def self.emojis
+    @emojis ||= begin
+      json_path = File.join(Rails.root, 'fixtures', 'emojis', 'index.json' )
+      JSON.parse(File.read(json_path))
+    end
+  end
+
+  def self.aliases
+    @aliases ||= begin
+      json_path = File.join(Rails.root, 'fixtures', 'emojis', 'aliases.json' )
+      JSON.parse(File.read(json_path))
+    end
   end
 end
diff --git a/lib/banzai/filter/abstract_reference_filter.rb b/lib/banzai/filter/abstract_reference_filter.rb
index bdaa4721b4bcdc863f07f1dab60f3bc4bd22f292..63ad8910c0ff31b774051f4e66a4ea145a041a21 100644
--- a/lib/banzai/filter/abstract_reference_filter.rb
+++ b/lib/banzai/filter/abstract_reference_filter.rb
@@ -98,7 +98,7 @@ module Banzai
           project = project_from_ref(project_ref)
 
           if project && object = find_object(project, id)
-            title = escape_once(object_link_title(object))
+            title = object_link_title(object)
             klass = reference_class(object_sym)
 
             data  = data_attribute(
@@ -110,17 +110,11 @@ module Banzai
             url = matches[:url] if matches.names.include?("url")
             url ||= url_for_object(object, project)
 
-            text = link_text
-            unless text
-              text = object.reference_link_text(context[:project])
-
-              extras = object_link_text_extras(object, matches)
-              text += " (#{extras.join(", ")})" if extras.any?
-            end
+            text = link_text || object_link_text(object, matches)
 
             %(<a href="#{url}" #{data}
-                 title="#{title}"
-                 class="#{klass}">#{text}</a>)
+                 title="#{escape_once(title)}"
+                 class="#{klass}">#{escape_once(text)}</a>)
           else
             match
           end
@@ -140,6 +134,15 @@ module Banzai
       def object_link_title(object)
         "#{object_class.name.titleize}: #{object.title}"
       end
+
+      def object_link_text(object, matches)
+        text = object.reference_link_text(context[:project])
+
+        extras = object_link_text_extras(object, matches)
+        text += " (#{extras.join(", ")})" if extras.any?
+
+        text
+      end
     end
   end
 end
diff --git a/lib/banzai/filter/external_issue_reference_filter.rb b/lib/banzai/filter/external_issue_reference_filter.rb
index f5737a7ac193afb9d40d96e7838371adefd72154..6136e73c096ab7df26c281a903840b64695e0803 100644
--- a/lib/banzai/filter/external_issue_reference_filter.rb
+++ b/lib/banzai/filter/external_issue_reference_filter.rb
@@ -23,6 +23,18 @@ module Banzai
         end
       end
 
+      def self.referenced_by(node)
+        project = Project.find(node.attr("data-project")) rescue nil
+        return unless project
+
+        id = node.attr("data-external-issue")
+        external_issue = ExternalIssue.new(id, project)
+
+        return unless external_issue
+
+        { external_issue: external_issue }
+      end
+
       def call
         # Early return if the project isn't using an external tracker
         return doc if project.nil? || project.default_issues_tracker?
@@ -46,18 +58,20 @@ module Banzai
       def issue_link_filter(text, link_text: nil)
         project = context[:project]
 
-        self.class.references_in(text) do |match, issue|
-          url = url_for_issue(issue, project, only_path: context[:only_path])
+        self.class.references_in(text) do |match, id|
+          ExternalIssue.new(id, project)
+
+          url = url_for_issue(id, project, only_path: context[:only_path])
 
-          title = escape_once("Issue in #{project.external_issue_tracker.title}")
+          title = "Issue in #{project.external_issue_tracker.title}"
           klass = reference_class(:issue)
-          data  = data_attribute(project: project.id)
+          data  = data_attribute(project: project.id, external_issue: id)
 
           text = link_text || match
 
           %(<a href="#{url}" #{data}
-               title="#{title}"
-               class="#{klass}">#{text}</a>)
+               title="#{escape_once(title)}"
+               class="#{klass}">#{escape_once(text)}</a>)
         end
       end
 
diff --git a/lib/banzai/filter/label_reference_filter.rb b/lib/banzai/filter/label_reference_filter.rb
index 07bac2dd7fd4897fcee8ea09567f803ceff03c58..a3a7a23c1e6ae272f950dcb76154c837d830c3e0 100644
--- a/lib/banzai/filter/label_reference_filter.rb
+++ b/lib/banzai/filter/label_reference_filter.rb
@@ -60,7 +60,7 @@ module Banzai
             text = link_text || render_colored_label(label)
 
             %(<a href="#{url}" #{data}
-                 class="#{klass}">#{text}</a>)
+                 class="#{klass}">#{escape_once(text)}</a>)
           else
             match
           end
diff --git a/lib/banzai/filter/reference_filter.rb b/lib/banzai/filter/reference_filter.rb
index 33457a3f361837e6daa228047fa48080ab80d09e..a22a7a7afd31e379b01a9fbec41cf04d143c5878 100644
--- a/lib/banzai/filter/reference_filter.rb
+++ b/lib/banzai/filter/reference_filter.rb
@@ -44,11 +44,11 @@ module Banzai
       # Returns a String
       def data_attribute(attributes = {})
         attributes[:reference_filter] = self.class.name.demodulize
-        attributes.map { |key, value| %Q(data-#{key.to_s.dasherize}="#{value}") }.join(" ")
+        attributes.map { |key, value| %Q(data-#{key.to_s.dasherize}="#{escape_once(value)}") }.join(" ")
       end
 
       def escape_once(html)
-        ERB::Util.html_escape_once(html)
+        html.html_safe? ? html : ERB::Util.html_escape_once(html)
       end
 
       def ignore_parents
diff --git a/lib/banzai/filter/user_reference_filter.rb b/lib/banzai/filter/user_reference_filter.rb
index 67c24faf991243f4aa167fbde94ff17a9ccbc129..7f302d51dd79c45fcd8ccf8eee339a476bfa7f78 100644
--- a/lib/banzai/filter/user_reference_filter.rb
+++ b/lib/banzai/filter/user_reference_filter.rb
@@ -122,7 +122,7 @@ module Banzai
       end
 
       def link_tag(url, data, text)
-        %(<a href="#{url}" #{data} class="#{link_class}">#{text}</a>)
+        %(<a href="#{url}" #{data} class="#{link_class}">#{escape_once(text)}</a>)
       end
     end
   end
diff --git a/lib/ci/api/helpers.rb b/lib/ci/api/helpers.rb
index 443563c2e4a4c8b1cb48af76ff093c891ad25fd0..1c91204e98ca1c9331f0c597d4e8bb5933b3c7cd 100644
--- a/lib/ci/api/helpers.rb
+++ b/lib/ci/api/helpers.rb
@@ -19,7 +19,7 @@ module Ci
       end
 
       def runner_registration_token_valid?
-        params[:token] == current_application_settings.ensure_runners_registration_token
+        params[:token] == current_application_settings.runners_registration_token
       end
 
       def update_runner_last_contact
diff --git a/lib/gitlab/git.rb b/lib/gitlab/git.rb
index 0c350d7c675e1977077944a7c1eff2f5a355c93b..f065cc5e9e9962c70407370403881452dab5c795 100644
--- a/lib/gitlab/git.rb
+++ b/lib/gitlab/git.rb
@@ -20,6 +20,10 @@ module Gitlab
       def blank_ref?(ref)
         ref == BLANK_SHA
       end
+
+      def version
+        Gitlab::VersionInfo.parse(Gitlab::Popen.popen(%W(#{Gitlab.config.git.bin_path} --version)).first)
+      end
     end
   end
 end
diff --git a/lib/gitlab/ldap/user.rb b/lib/gitlab/ldap/user.rb
index 4be99dd88c29dd87ba829973da60aeca464dbf2d..aef08c97d1d7edf18a23b02f82a0eedcb5af40e1 100644
--- a/lib/gitlab/ldap/user.rb
+++ b/lib/gitlab/ldap/user.rb
@@ -14,7 +14,7 @@ module Gitlab
           # LDAP distinguished name is case-insensitive
           identity = ::Identity.
             where(provider: provider).
-            where('lower(extern_uid) = ?', uid.mb_chars.downcase.to_s).last
+            iwhere(extern_uid: uid).last
           identity && identity.user
         end
       end
@@ -31,7 +31,7 @@ module Gitlab
 
       def find_by_uid_and_provider
         self.class.find_by_uid_and_provider(
-          auth_hash.uid.downcase, auth_hash.provider)
+          auth_hash.uid, auth_hash.provider)
       end
 
       def find_by_email
@@ -47,7 +47,7 @@ module Gitlab
         # find_or_initialize_by doesn't update `gl_user.identities`, and isn't autosaved.
         identity = gl_user.identities.find { |identity|  identity.provider == auth_hash.provider }
         identity ||= gl_user.identities.build(provider: auth_hash.provider)
-        
+
         # For a new user set extern_uid to the LDAP DN
         # For an existing user with matching email but changed DN, update the DN.
         # For an existing user with no change in DN, this line changes nothing.
diff --git a/lib/gitlab/o_auth/session.rb b/lib/gitlab/o_auth/session.rb
new file mode 100644
index 0000000000000000000000000000000000000000..f33bfd0bd0e684e6ca8ba31796b1878889b2c8f1
--- /dev/null
+++ b/lib/gitlab/o_auth/session.rb
@@ -0,0 +1,17 @@
+module Gitlab
+  module OAuth
+    module Session
+      def self.create(provider, ticket)
+        Rails.cache.write("gitlab:#{provider}:#{ticket}", ticket, expires_in: Gitlab.config.omniauth.cas3.session_duration)
+      end
+
+      def self.destroy(provider, ticket)
+        Rails.cache.delete("gitlab:#{provider}:#{ticket}")
+      end
+
+      def self.valid?(provider, ticket)
+        Rails.cache.read("gitlab:#{provider}:#{ticket}").present?
+      end
+    end
+  end
+end
diff --git a/lib/gitlab/o_auth/user.rb b/lib/gitlab/o_auth/user.rb
index 17ce4d4b1747e7004ed7e628b5c01f85008df745..f1a362f5303a296099c4ed7c725312b9498605a1 100644
--- a/lib/gitlab/o_auth/user.rb
+++ b/lib/gitlab/o_auth/user.rb
@@ -64,7 +64,7 @@ module Gitlab
 
         # If a corresponding person exists with same uid in a LDAP server,
         # set up a Gitlab user with dual LDAP and Omniauth identities.
-        if user = Gitlab::LDAP::User.find_by_uid_and_provider(ldap_person.dn.downcase, ldap_person.provider)
+        if user = Gitlab::LDAP::User.find_by_uid_and_provider(ldap_person.dn, ldap_person.provider)
           # Case when a LDAP user already exists in Gitlab. Add the Omniauth identity to existing account.
           user.identities.build(extern_uid: auth_hash.uid, provider: auth_hash.provider)
         else
diff --git a/lib/gitlab/reference_extractor.rb b/lib/gitlab/reference_extractor.rb
index 42f7c26f3c4a10a8d0b0834c81daa2beab2f2bd5..0a70d21b1cea210f40ee5159b4d004c2e6d8d3ac 100644
--- a/lib/gitlab/reference_extractor.rb
+++ b/lib/gitlab/reference_extractor.rb
@@ -18,10 +18,20 @@ module Gitlab
       super(text, context.merge(project: project))
     end
 
-    %i(user label issue merge_request snippet commit commit_range).each do |type|
+    %i(user label merge_request snippet commit commit_range).each do |type|
       define_method("#{type}s") do
         @references[type] ||= references(type, project: project, current_user: current_user)
       end
     end
+
+    def issues
+      options = { project: project, current_user: current_user }
+
+      if project && project.jira_tracker?
+        @references[:external_issue] ||= references(:external_issue, options)
+      else
+        @references[:issue] ||= references(:issue, options)
+      end
+    end
   end
 end
diff --git a/lib/gitlab/visibility_level.rb b/lib/gitlab/visibility_level.rb
index 335dc44be19d2cee966cbb6d407d11c0f4db23d4..3160a3c7582547aa117bae1285e0e3ce9424e2d4 100644
--- a/lib/gitlab/visibility_level.rb
+++ b/lib/gitlab/visibility_level.rb
@@ -51,6 +51,15 @@ module Gitlab
       def allowed_fork_levels(origin_level)
         [PRIVATE, INTERNAL, PUBLIC].select{ |level| level <= origin_level }
       end
+
+      def level_name(level)
+        level_name = 'Unknown'
+        options.each do |name, lvl|
+          level_name = name if lvl == level.to_i
+        end
+
+        level_name
+      end
     end
 
     def private?
diff --git a/lib/support/init.d/gitlab b/lib/support/init.d/gitlab
index aa2da92c13832dbfbf4481c3572104e3a0820b75..c5f07c8b508a948796901b0cf6bcc5024360ba71 100755
--- a/lib/support/init.d/gitlab
+++ b/lib/support/init.d/gitlab
@@ -92,7 +92,7 @@ check_pids(){
 
 ## Called when we have started the two processes and are waiting for their pid files.
 wait_for_pids(){
-  # We are sleeping a bit here mostly because sidekiq is slow at writing it's pid
+  # We are sleeping a bit here mostly because sidekiq is slow at writing its pid
   i=0;
   while [ ! -f $web_server_pid_path ] || [ ! -f $sidekiq_pid_path ] || [ ! -f $gitlab_workhorse_pid_path ] || { [ "$mail_room_enabled" = true ] && [ ! -f $mail_room_pid_path ]; }; do
     sleep 0.1;
@@ -108,7 +108,7 @@ wait_for_pids(){
 }
 
 # We use the pids in so many parts of the script it makes sense to always check them.
-# Only after start() is run should the pids change. Sidekiq sets it's own pid.
+# Only after start() is run should the pids change. Sidekiq sets its own pid.
 check_pids
 
 
@@ -290,7 +290,7 @@ stop_gitlab() {
   sleep 1
   # Cleaning up unused pids
   rm "$web_server_pid_path" 2>/dev/null
-  # rm "$sidekiq_pid_path" 2>/dev/null # Sidekiq seems to be cleaning up it's own pid.
+  # rm "$sidekiq_pid_path" 2>/dev/null # Sidekiq seems to be cleaning up its own pid.
   rm -f "$gitlab_workhorse_pid_path"
   if [ "$mail_room_enabled" = true ]; then
     rm "$mail_room_pid_path" 2>/dev/null
@@ -299,7 +299,7 @@ stop_gitlab() {
   print_status
 }
 
-## Prints the status of GitLab and it's components.
+## Prints the status of GitLab and its components.
 print_status() {
   check_status
   if [ "$web_status" != "0" ] && [ "$sidekiq_status" != "0" ] && [ "$gitlab_workhorse_status" != "0" ] && { [ "$mail_room_enabled" != true ] || [ "$mail_room_status" != "0" ]; }; then
@@ -333,7 +333,7 @@ print_status() {
   fi
 }
 
-## Tells unicorn to reload it's config and Sidekiq to restart
+## Tells unicorn to reload its config and Sidekiq to restart
 reload_gitlab(){
   exit_if_not_running
   if [ "$wpid" = "0" ];then
diff --git a/lib/support/init.d/gitlab.default.example b/lib/support/init.d/gitlab.default.example
index 7fc495db5455b372ef8ce2117d16d06b3480ce76..1937ca582b0548939c42d2aca1bab39b45357b2a 100755
--- a/lib/support/init.d/gitlab.default.example
+++ b/lib/support/init.d/gitlab.default.example
@@ -9,11 +9,11 @@ RAILS_ENV="production"
 # The default is "git".
 app_user="git"
 
-# app_root defines the folder in which gitlab and it's components are installed.
+# app_root defines the folder in which gitlab and its components are installed.
 # The default is "/home/$app_user/gitlab"
 app_root="/home/$app_user/gitlab"
 
-# pid_path defines a folder in which the gitlab and it's components place their pids.
+# pid_path defines a folder in which the gitlab and its components place their pids.
 # This variable is also used below to define the relevant pids for the gitlab components.
 # The default is "$app_root/tmp/pids"
 pid_path="$app_root/tmp/pids"
diff --git a/spec/controllers/projects/tree_controller_spec.rb b/spec/controllers/projects/tree_controller_spec.rb
index a474574c6e5a40284b9a57e9d6ad9ffdd44b81a5..e74731c9ed82b07093aa3718306dbeac5ce9bebe 100644
--- a/spec/controllers/projects/tree_controller_spec.rb
+++ b/spec/controllers/projects/tree_controller_spec.rb
@@ -98,7 +98,7 @@ describe Projects::TreeController do
            project_id: project.to_param,
            id: 'master',
            dir_name: path,
-           new_branch: target_branch,
+           target_branch: target_branch,
            commit_message: 'Test commit message')
     end
 
@@ -108,8 +108,8 @@ describe Projects::TreeController do
 
       it 'redirects to the new directory' do
         expect(subject).
-            to redirect_to("/#{project.path_with_namespace}/blob/#{target_branch}/#{path}")
-        expect(flash[:notice]).to eq('The directory has been successfully created')
+            to redirect_to("/#{project.path_with_namespace}/tree/#{target_branch}/#{path}")
+        expect(flash[:notice]).to eq('The directory has been successfully created.')
       end
     end
 
@@ -119,7 +119,7 @@ describe Projects::TreeController do
 
       it 'does not allow overwriting of existing files' do
         expect(subject).
-            to redirect_to("/#{project.path_with_namespace}/blob/master")
+            to redirect_to("/#{project.path_with_namespace}/tree/master")
         expect(flash[:alert]).to eq('Directory already exists as a file')
       end
     end
diff --git a/spec/features/admin/admin_runners_spec.rb b/spec/features/admin/admin_runners_spec.rb
index 66a2cc0c157a90737ab32cdb29055552d926079e..26d03944b8a24dd811e1a6da96f05b73118ae215 100644
--- a/spec/features/admin/admin_runners_spec.rb
+++ b/spec/features/admin/admin_runners_spec.rb
@@ -63,7 +63,7 @@ describe "Admin Runners" do
   end
 
   describe 'runners registration token' do
-    let!(:token) { current_application_settings.ensure_runners_registration_token }
+    let!(:token) { current_application_settings.runners_registration_token }
     before { visit admin_runners_path }
 
     it 'has a registration token' do
diff --git a/spec/features/ci_lint_spec.rb b/spec/features/ci_lint_spec.rb
new file mode 100644
index 0000000000000000000000000000000000000000..e6e73e5e67ca34dd3ea2734fc30842bdf0d9c6a2
--- /dev/null
+++ b/spec/features/ci_lint_spec.rb
@@ -0,0 +1,39 @@
+require 'spec_helper'
+
+describe 'CI Lint' do
+  before do
+    login_as :user
+  end
+
+  describe 'YAML parsing' do
+    before do
+      visit ci_lint_path
+      fill_in 'content', with: yaml_content
+      click_on 'Validate'
+    end
+
+    context 'YAML is correct' do
+      let(:yaml_content) do
+        File.read(Rails.root.join('spec/support/gitlab_stubs/gitlab_ci.yml'))
+      end
+
+      it 'Yaml parsing' do
+        within "table" do
+          expect(page).to have_content('Job - rspec')
+          expect(page).to have_content('Job - spinach')
+          expect(page).to have_content('Deploy Job - staging')
+          expect(page).to have_content('Deploy Job - production')
+        end
+      end
+    end
+
+    context 'YAML is incorrect' do
+      let(:yaml_content) { '' }
+
+      it 'displays information about an error' do
+        expect(page).to have_content('Status: syntax is incorrect')
+        expect(page).to have_content('Error: Please provide content of .gitlab-ci.yml')
+      end
+    end
+  end
+end
diff --git a/spec/features/lint_spec.rb b/spec/features/lint_spec.rb
deleted file mode 100644
index 5d8f56e2cfb160bac8f81f0e6a41e276d0a7713a..0000000000000000000000000000000000000000
--- a/spec/features/lint_spec.rb
+++ /dev/null
@@ -1,28 +0,0 @@
-require 'spec_helper'
-
-describe "Lint" do
-  before do
-    login_as :user
-  end
-
-  it "Yaml parsing", js: true do
-    content = File.read(Rails.root.join('spec/support/gitlab_stubs/gitlab_ci.yml'))
-    visit ci_lint_path 
-    fill_in "content", with: content
-    click_on "Validate"
-    within "table" do
-      expect(page).to have_content("Job - rspec")
-      expect(page).to have_content("Job - spinach")
-      expect(page).to have_content("Deploy Job - staging")
-      expect(page).to have_content("Deploy Job - production")
-    end
-  end
-
-  it "Yaml parsing with error", js: true do
-    visit ci_lint_path
-    fill_in "content", with: ""
-    click_on "Validate"
-    expect(page).to have_content("Status: syntax is incorrect")
-    expect(page).to have_content("Error: Please provide content of .gitlab-ci.yml")
-  end
-end
diff --git a/spec/features/projects_spec.rb b/spec/features/projects_spec.rb
index 09fcff2444ac83771442c68f0935fd591fdd4305..74b148f5d178b44fb55aa3340cbca7f4fefc5180 100644
--- a/spec/features/projects_spec.rb
+++ b/spec/features/projects_spec.rb
@@ -70,6 +70,20 @@ feature 'Project', feature: true do
     end
   end
 
+  describe 'leave project link' do
+    let(:user)    { create(:user) }
+    let(:project) { create(:project, namespace: user.namespace) }
+
+    before do
+      login_with(user)
+      project.team.add_user(user, Gitlab::Access::MASTER)
+      visit namespace_project_path(project.namespace, project)
+    end
+
+    it { expect(page).to have_content('You have Master access to this project.') }
+    it { expect(page).to have_link('Leave this project') }
+  end
+
   def remove_with_confirm(button_text, confirm_with)
     click_button button_text
     fill_in 'confirm_name_input', with: confirm_with
diff --git a/spec/helpers/issues_helper_spec.rb b/spec/helpers/issues_helper_spec.rb
index 1f2c4ee77b59fdf79c94f5295f3c68048f5136c3..04e795025d20912cf7166f8d219a377d02bc120c 100644
--- a/spec/helpers/issues_helper_spec.rb
+++ b/spec/helpers/issues_helper_spec.rb
@@ -127,18 +127,6 @@ describe IssuesHelper do
     it { is_expected.to eq("!1, !2, or !3") }
   end
 
-  describe "#url_to_emoji" do
-    it "returns url" do
-      expect(url_to_emoji("smile")).to include("emoji/1F604.png")
-    end
-  end
-
-  describe "#emoji_list" do
-    it "returns url" do
-      expect(emoji_list).to be_kind_of(Array)
-    end
-  end
-
   describe "#note_active_class" do
     before do
       @note = create :note
diff --git a/spec/helpers/merge_requests_helper_spec.rb b/spec/helpers/merge_requests_helper_spec.rb
index 0ef1efb8bce1ee6c01105aab7be74fd62b8af73a..600e1c4e9ecf1727403f68d7cca18bb270be25d7 100644
--- a/spec/helpers/merge_requests_helper_spec.rb
+++ b/spec/helpers/merge_requests_helper_spec.rb
@@ -1,24 +1,57 @@
 require 'spec_helper'
 
 describe MergeRequestsHelper do
-  describe "#issues_sentence" do
+  describe 'ci_build_details_path' do
+    let(:project) { create :project }
+    let(:merge_request) { MergeRequest.new }
+    let(:ci_service) { CiService.new }
+    let(:last_commit) { Ci::Commit.new({}) }
+
+    before do
+      allow(merge_request).to receive(:source_project).and_return(project)
+      allow(merge_request).to receive(:last_commit).and_return(last_commit)
+      allow(project).to receive(:ci_service).and_return(ci_service)
+      allow(last_commit).to receive(:sha).and_return('12d65c')
+    end
+
+    it 'does not include api credentials in a link' do
+      allow(ci_service).
+        to receive(:build_page).and_return("http://secretuser:secretpass@jenkins.example.com:8888/job/test1/scm/bySHA1/12d65c")
+      expect(helper.ci_build_details_path(merge_request)).to_not match("secret")
+    end
+  end
+
+  describe '#issues_sentence' do
     subject { issues_sentence(issues) }
     let(:issues) do
       [build(:issue, iid: 1), build(:issue, iid: 2), build(:issue, iid: 3)]
     end
 
     it { is_expected.to eq('#1, #2, and #3') }
+
+    context 'for JIRA issues' do
+      let(:project) { create(:project) }
+      let(:issues) do
+        [
+          JiraIssue.new('JIRA-123', project),
+          JiraIssue.new('JIRA-456', project),
+          JiraIssue.new('FOOBAR-7890', project)
+        ]
+      end
+
+      it { is_expected.to eq('FOOBAR-7890, JIRA-123, and JIRA-456') }
+    end
   end
 
-  describe "#format_mr_branch_names" do
-    describe "within the same project" do
+  describe '#format_mr_branch_names' do
+    describe 'within the same project' do
       let(:merge_request) { create(:merge_request) }
       subject { format_mr_branch_names(merge_request) }
 
       it { is_expected.to eq([merge_request.source_branch, merge_request.target_branch]) }
     end
 
-    describe "within different projects" do
+    describe 'within different projects' do
       let(:project) { create(:project) }
       let(:fork_project) { create(:project, forked_from_project: project) }
       let(:merge_request) { create(:merge_request, source_project: fork_project, target_project: project) }
diff --git a/spec/helpers/projects_helper_spec.rb b/spec/helpers/projects_helper_spec.rb
index f2efb528aeb6cc1c9397e7a5c9a8676286f4085d..53207767581e906005768c4e3313ea0beca51b35 100644
--- a/spec/helpers/projects_helper_spec.rb
+++ b/spec/helpers/projects_helper_spec.rb
@@ -53,6 +53,16 @@ describe ProjectsHelper do
     end
   end
 
+  describe 'user_max_access_in_project' do
+    let(:project) { create(:project) }
+    let(:user) { create(:user) }
+    before do
+      project.team.add_user(user, Gitlab::Access::MASTER)
+    end
+
+    it { expect(helper.user_max_access_in_project(user.id, project)).to eq('Master') }
+  end
+
   describe "readme_cache_key" do
     let(:project) { create(:project) }
 
diff --git a/spec/javascripts/fixtures/new_branch.html.haml b/spec/javascripts/fixtures/new_branch.html.haml
new file mode 100644
index 0000000000000000000000000000000000000000..f06629e5eccd4ef5814c12e510479c3f0648af8d
--- /dev/null
+++ b/spec/javascripts/fixtures/new_branch.html.haml
@@ -0,0 +1,4 @@
+%form.js-create-branch-form
+  %input.js-branch-name
+  .js-branch-name-error
+  %input{id: "ref"}
diff --git a/spec/javascripts/new_branch_spec.js.coffee b/spec/javascripts/new_branch_spec.js.coffee
new file mode 100644
index 0000000000000000000000000000000000000000..f2ce85efcdcbbaac28c81ec75867d3723f587833
--- /dev/null
+++ b/spec/javascripts/new_branch_spec.js.coffee
@@ -0,0 +1,160 @@
+#= require jquery-ui
+#= require new_branch_form
+
+describe 'Branch', ->
+  describe 'create a new branch', ->
+    fixture.preload('new_branch.html')
+
+    fillNameWith = (value) ->
+      $('.js-branch-name').val(value).trigger('blur')
+
+    expectToHaveError = (error) ->
+      expect($('.js-branch-name-error span').text()).toEqual(error)
+
+    beforeEach ->
+      fixture.load('new_branch.html')
+      $('form').on 'submit', (e) -> e.preventDefault()
+
+      @form = new NewBranchForm($('.js-create-branch-form'), [])
+
+    it "can't start with a dot", ->
+      fillNameWith '.foo'
+      expectToHaveError "can't start with '.'"
+
+    it "can't start with a slash", ->
+      fillNameWith '/foo'
+      expectToHaveError "can't start with '/'"
+
+    it "can't have two consecutive dots", ->
+      fillNameWith 'foo..bar'
+      expectToHaveError "can't contain '..'"
+
+    it "can't have spaces anywhere", ->
+      fillNameWith ' foo'
+      expectToHaveError "can't contain spaces"
+      fillNameWith 'foo bar'
+      expectToHaveError "can't contain spaces"
+      fillNameWith 'foo '
+      expectToHaveError "can't contain spaces"
+
+    it "can't have ~ anywhere", ->
+      fillNameWith '~foo'
+      expectToHaveError "can't contain '~'"
+      fillNameWith 'foo~bar'
+      expectToHaveError "can't contain '~'"
+      fillNameWith 'foo~'
+      expectToHaveError "can't contain '~'"
+
+    it "can't have tilde anwhere", ->
+      fillNameWith '~foo'
+      expectToHaveError "can't contain '~'"
+      fillNameWith 'foo~bar'
+      expectToHaveError "can't contain '~'"
+      fillNameWith 'foo~'
+      expectToHaveError "can't contain '~'"
+
+    it "can't have caret anywhere", ->
+      fillNameWith '^foo'
+      expectToHaveError "can't contain '^'"
+      fillNameWith 'foo^bar'
+      expectToHaveError "can't contain '^'"
+      fillNameWith 'foo^'
+      expectToHaveError "can't contain '^'"
+
+    it "can't have : anywhere", ->
+      fillNameWith ':foo'
+      expectToHaveError "can't contain ':'"
+      fillNameWith 'foo:bar'
+      expectToHaveError "can't contain ':'"
+      fillNameWith ':foo'
+      expectToHaveError "can't contain ':'"
+
+    it "can't have question mark anywhere", ->
+      fillNameWith '?foo'
+      expectToHaveError "can't contain '?'"
+      fillNameWith 'foo?bar'
+      expectToHaveError "can't contain '?'"
+      fillNameWith 'foo?'
+      expectToHaveError "can't contain '?'"
+
+    it "can't have asterisk anywhere", ->
+      fillNameWith '*foo'
+      expectToHaveError "can't contain '*'"
+      fillNameWith 'foo*bar'
+      expectToHaveError "can't contain '*'"
+      fillNameWith 'foo*'
+      expectToHaveError "can't contain '*'"
+
+    it "can't have open bracket anywhere", ->
+      fillNameWith '[foo'
+      expectToHaveError "can't contain '['"
+      fillNameWith 'foo[bar'
+      expectToHaveError "can't contain '['"
+      fillNameWith 'foo['
+      expectToHaveError "can't contain '['"
+
+    it "can't have a backslash anywhere", ->
+      fillNameWith '\\foo'
+      expectToHaveError "can't contain '\\'"
+      fillNameWith 'foo\\bar'
+      expectToHaveError "can't contain '\\'"
+      fillNameWith 'foo\\'
+      expectToHaveError "can't contain '\\'"
+
+    it "can't contain a sequence @{ anywhere", ->
+      fillNameWith '@{foo'
+      expectToHaveError "can't contain '@{'"
+      fillNameWith 'foo@{bar'
+      expectToHaveError "can't contain '@{'"
+      fillNameWith 'foo@{'
+      expectToHaveError "can't contain '@{'"
+
+    it "can't have consecutive slashes", ->
+      fillNameWith 'foo//bar'
+      expectToHaveError "can't contain consecutive slashes"
+
+    it "can't end with a slash", ->
+      fillNameWith 'foo/'
+      expectToHaveError "can't end in '/'"
+
+    it "can't end with a dot", ->
+      fillNameWith 'foo.'
+      expectToHaveError "can't end in '.'"
+
+    it "can't end with .lock", ->
+      fillNameWith 'foo.lock'
+      expectToHaveError "can't end in '.lock'"
+
+    it "can't be the single character @", ->
+      fillNameWith '@'
+      expectToHaveError "can't be '@'"
+
+    it "concatenates all error messages", ->
+      fillNameWith '/foo bar?~.'
+      expectToHaveError "can't start with '/', can't contain spaces, '?', '~', can't end in '.'"
+
+    it "doesn't duplicate error messages", ->
+      fillNameWith '?foo?bar?zoo?'
+      expectToHaveError "can't contain '?'"
+
+    it "removes the error message when is a valid name", ->
+      fillNameWith 'foo?bar'
+      expect($('.js-branch-name-error span').length).toEqual(1)
+      fillNameWith 'foobar'
+      expect($('.js-branch-name-error span').length).toEqual(0)
+
+    it "can have dashes anywhere", ->
+      fillNameWith '-foo-bar-zoo-'
+      expect($('.js-branch-name-error span').length).toEqual(0)
+
+    it "can have underscores anywhere", ->
+      fillNameWith '_foo_bar_zoo_'
+      expect($('.js-branch-name-error span').length).toEqual(0)
+
+    it "can have numbers anywhere", ->
+      fillNameWith '1foo2bar3zoo4'
+      expect($('.js-branch-name-error span').length).toEqual(0)
+
+    it "can be only letters", ->
+      fillNameWith 'foo'
+      expect($('.js-branch-name-error span').length).toEqual(0)
diff --git a/spec/lib/gitlab/ldap/user_spec.rb b/spec/lib/gitlab/ldap/user_spec.rb
index 3bba5e2efa2c930c4ee406232c1e9349e72162a2..1e755259dae4a4bdb85e0f1eccd5ff8ccebefa23 100644
--- a/spec/lib/gitlab/ldap/user_spec.rb
+++ b/spec/lib/gitlab/ldap/user_spec.rb
@@ -42,6 +42,21 @@ describe Gitlab::LDAP::User, lib: true do
     end
   end
 
+  describe '.find_by_uid_and_provider' do
+    it 'retrieves the correct user' do
+      special_info = {
+        name: 'John Åström',
+        email: 'john@example.com',
+        nickname: 'jastrom'
+      }
+      special_hash = OmniAuth::AuthHash.new(uid: 'CN=John Åström,CN=Users,DC=Example,DC=com', provider: 'ldapmain', info: special_info)
+      special_chars_user = described_class.new(special_hash)
+      user = special_chars_user.save
+
+      expect(described_class.find_by_uid_and_provider(special_hash.uid, special_hash.provider)).to eq user
+    end
+  end
+
   describe :find_or_create do
     it "finds the user if already existing" do
       create(:omniauth_user, extern_uid: 'my-uid', provider: 'ldapmain')
diff --git a/spec/lib/gitlab/reference_extractor_spec.rb b/spec/lib/gitlab/reference_extractor_spec.rb
index 66dc5d4911d8cd064e455e03ff3099c1646b71d5..7d963795e17b48265d15c55ac92d4b4598716409 100644
--- a/spec/lib/gitlab/reference_extractor_spec.rb
+++ b/spec/lib/gitlab/reference_extractor_spec.rb
@@ -97,6 +97,16 @@ describe Gitlab::ReferenceExtractor, lib: true do
     expect(extracted.first.commit_to).to eq commit
   end
 
+  context 'with an external issue tracker' do
+    let(:project) { create(:jira_project) }
+    subject { described_class.new(project, project.creator) }
+
+    it 'returns JIRA issues for a JIRA-integrated project' do
+      subject.analyze('JIRA-123 and FOOBAR-4567')
+      expect(subject.issues).to eq [JiraIssue.new('JIRA-123', project), JiraIssue.new('FOOBAR-4567', project)]
+    end
+  end
+
   context 'with a project with an underscore' do
     let(:other_project) { create(:project, path: 'test_project') }
     let(:issue) { create(:issue, project: other_project) }
diff --git a/spec/models/build_spec.rb b/spec/models/build_spec.rb
index 96b6f1dbca6b24e365a367bdef7acfc0e8cb03d4..1c22e3cb7c405363d30a575ce90178341f345da8 100644
--- a/spec/models/build_spec.rb
+++ b/spec/models/build_spec.rb
@@ -189,6 +189,12 @@ describe Ci::Build, models: true do
 
       it { is_expected.to eq(98.29) }
     end
+
+    context 'using a regex capture' do
+      subject { build.extract_coverage('TOTAL      9926   3489    65%', 'TOTAL\s+\d+\s+\d+\s+(\d{1,3}\%)') }
+
+      it { is_expected.to eq(65) }
+    end
   end
 
   describe :variables do
@@ -390,4 +396,68 @@ describe Ci::Build, models: true do
     it { is_expected.to include('gitlab-ci-token') }
     it { is_expected.to include(project.web_url[7..-1]) }
   end
+
+  def create_mr(build, commit, factory: :merge_request, created_at: Time.now)
+    FactoryGirl.create(factory,
+                       source_project_id: commit.gl_project_id,
+                       target_project_id: commit.gl_project_id,
+                       source_branch: build.ref,
+                       created_at: created_at)
+  end
+
+  describe :merge_request do
+    context 'when a MR has a reference to the commit' do
+      before do
+        @merge_request = create_mr(build, commit, factory: :merge_request)
+
+        commits = [double(id: commit.sha)]
+        allow(@merge_request).to receive(:commits).and_return(commits)
+        allow(MergeRequest).to receive_message_chain(:includes, :where, :reorder).and_return([@merge_request])
+      end
+
+      it 'returns the single associated MR' do
+        expect(build.merge_request.id).to eq(@merge_request.id)
+      end
+    end
+
+    context 'when there is not a MR referencing the commit' do
+      it 'returns nil' do
+        expect(build.merge_request).to be_nil
+      end
+    end
+
+    context 'when more than one MR have a reference to the commit' do
+      before do
+        @merge_request = create_mr(build, commit, factory: :merge_request)
+        @merge_request.close!
+        @merge_request2 = create_mr(build, commit, factory: :merge_request)
+
+        commits = [double(id: commit.sha)]
+        allow(@merge_request).to receive(:commits).and_return(commits)
+        allow(@merge_request2).to receive(:commits).and_return(commits)
+        allow(MergeRequest).to receive_message_chain(:includes, :where, :reorder).and_return([@merge_request, @merge_request2])
+      end
+
+      it 'returns the first MR' do
+        expect(build.merge_request.id).to eq(@merge_request.id)
+      end
+    end
+
+    context 'when a Build is created after the MR' do
+      before do
+        @merge_request = create_mr(build, commit, factory: :merge_request_with_diffs)
+        commit2 = FactoryGirl.create :ci_commit, project: project
+        @build2 = FactoryGirl.create :ci_build, commit: commit2
+
+        commits = [double(id: commit.sha), double(id: commit2.sha)]
+        allow(@merge_request).to receive(:commits).and_return(commits)
+        allow(MergeRequest).to receive_message_chain(:includes, :where, :reorder).and_return([@merge_request])
+      end
+
+      it 'returns the current MR' do
+        expect(@build2.merge_request.id).to eq(@merge_request.id)
+      end
+    end
+
+  end
 end
diff --git a/spec/models/concerns/mentionable_spec.rb b/spec/models/concerns/mentionable_spec.rb
index 6179882e93591f4556ddc9062b5c3ebba2dd14c0..6653621a83ed88e479963a448ad882e48ac40117 100644
--- a/spec/models/concerns/mentionable_spec.rb
+++ b/spec/models/concerns/mentionable_spec.rb
@@ -1,5 +1,18 @@
 require 'spec_helper'
 
+describe Mentionable do
+  include Mentionable
+
+  describe :references do
+    let(:project) { create(:project) }
+
+    it 'excludes JIRA references' do
+      allow(project).to receive_messages(jira_tracker?: true)
+      expect(referenced_mentionables(project, 'JIRA-123')).to be_empty
+    end
+  end
+end
+
 describe Issue, "Mentionable" do
   describe '#mentioned_users' do
     let!(:user) { create(:user, username: 'stranger') }
diff --git a/spec/models/concerns/token_authenticatable_spec.rb b/spec/models/concerns/token_authenticatable_spec.rb
index a9b0b64e5deccaa9663f8a701936de37133f70a1..30c0a04b84045b315094c1fb9a9b380de70f4a53 100644
--- a/spec/models/concerns/token_authenticatable_spec.rb
+++ b/spec/models/concerns/token_authenticatable_spec.rb
@@ -2,7 +2,8 @@ require 'spec_helper'
 
 shared_examples 'TokenAuthenticatable' do
   describe 'dynamically defined methods' do
-    it { expect(described_class).to be_private_method_defined(:generate_token_for) }
+    it { expect(described_class).to be_private_method_defined(:generate_token) }
+    it { expect(described_class).to be_private_method_defined(:write_new_token) }
     it { expect(described_class).to respond_to("find_by_#{token_field}") }
     it { is_expected.to respond_to("ensure_#{token_field}") }
     it { is_expected.to respond_to("reset_#{token_field}!") }
@@ -24,11 +25,11 @@ describe ApplicationSetting, 'TokenAuthenticatable' do
   it_behaves_like 'TokenAuthenticatable'
 
   describe 'generating new token' do
-    subject { described_class.new }
-    let(:token) { subject.send(token_field) }
-
     context 'token is not generated yet' do
-      it { expect(token).to be nil }
+      describe 'token field accessor' do
+        subject { described_class.new.send(token_field) }
+        it { is_expected.to_not be_blank }
+      end
 
       describe 'ensured token' do
         subject { described_class.new.send("ensure_#{token_field}") }
@@ -36,11 +37,21 @@ describe ApplicationSetting, 'TokenAuthenticatable' do
         it { is_expected.to be_a String }
         it { is_expected.to_not be_blank }
       end
+
+      describe 'ensured! token' do
+        subject { described_class.new.send("ensure_#{token_field}!") }
+
+        it 'should persist new token' do
+          expect(subject).to eq described_class.current[token_field]
+        end
+      end
     end
 
     context 'token is generated' do
       before { subject.send("reset_#{token_field}!") }
-      it { expect(token).to be_a String }
+      it 'persists a new token 'do
+        expect(subject.send(:read_attribute, token_field)).to be_a String
+      end
     end
   end
 
diff --git a/spec/models/global_milestone_spec.rb b/spec/models/global_milestone_spec.rb
index ba03e6aabd0352ecae60e036edd3e03b895b016a..197c99cd007ea9c80f30ef2474210b85d1d57907 100644
--- a/spec/models/global_milestone_spec.rb
+++ b/spec/models/global_milestone_spec.rb
@@ -62,4 +62,14 @@ describe GlobalMilestone, models: true do
       expect(@global_milestone.milestones.count).to eq(3)
     end
   end
+
+  describe :safe_title do
+    let(:milestone) { create(:milestone, title: "git / test", project: project1) }
+
+    it 'should strip out slashes and spaces' do
+      global_milestone = GlobalMilestone.new(milestone.title, [milestone])
+
+      expect(global_milestone.safe_title).to eq('git-test')
+    end
+  end
 end
diff --git a/spec/models/jira_issue_spec.rb b/spec/models/jira_issue_spec.rb
new file mode 100644
index 0000000000000000000000000000000000000000..1634265b439d1c18e8fd5ae4f010aa91cdc83cf1
--- /dev/null
+++ b/spec/models/jira_issue_spec.rb
@@ -0,0 +1,30 @@
+require 'spec_helper'
+
+describe JiraIssue do
+  let(:project) { create(:project) }
+  subject { JiraIssue.new('JIRA-123', project) }
+
+  describe 'id' do
+    subject { super().id }
+    it { is_expected.to eq('JIRA-123') }
+  end
+
+  describe 'iid' do
+    subject { super().iid }
+    it { is_expected.to eq('JIRA-123') }
+  end
+
+  describe 'to_s' do
+    subject { super().to_s }
+    it { is_expected.to eq('JIRA-123') }
+  end
+
+  describe :== do
+    specify { expect(subject).to eq(JiraIssue.new('JIRA-123', project)) }
+    specify { expect(subject).not_to eq(JiraIssue.new('JIRA-124', project)) }
+
+    it 'only compares with JiraIssues' do
+      expect(subject).not_to eq('JIRA-123')
+    end
+  end
+end
diff --git a/spec/models/merge_request_spec.rb b/spec/models/merge_request_spec.rb
index 1aeba9b2b3bcef80dbdf80053ac632b34be003af..e0653a8327d61ac6de3dfdac0c8090bbbfb1ac2f 100644
--- a/spec/models/merge_request_spec.rb
+++ b/spec/models/merge_request_spec.rb
@@ -164,6 +164,17 @@ describe MergeRequest, models: true do
 
       expect(subject.closes_issues).to include(issue2)
     end
+
+    context 'for a project with JIRA integration' do
+      let(:issue0) { JiraIssue.new('JIRA-123', subject.project) }
+      let(:issue1) { JiraIssue.new('FOOBAR-4567', subject.project) }
+
+      it 'returns sorted JiraIssues' do
+        allow(subject.project).to receive_messages(default_branch: subject.target_branch)
+
+        expect(subject.closes_issues).to eq([issue0, issue1])
+      end
+    end
   end
 
   describe "#work_in_progress?" do
diff --git a/spec/models/note_spec.rb b/spec/models/note_spec.rb
index 216c7dabae03f910b17ff1e30c2f62aa0b47433b..b7006fa5e68c8503adcacd917f7bae3a55d9dd0c 100644
--- a/spec/models/note_spec.rb
+++ b/spec/models/note_spec.rb
@@ -164,8 +164,8 @@ describe Note, models: true do
     let(:issue) { create :issue }
 
     it "converts aliases to actual name" do
-      note = create :note, note: ":thumbsup:", noteable: issue
-      expect(note.reload.note).to eq("+1")
+      note = create :note, note: ":+1:", noteable: issue
+      expect(note.reload.note).to eq("thumbsup")
     end
   end
 end
diff --git a/spec/models/project_services/jira_service_spec.rb b/spec/models/project_services/jira_service_spec.rb
index 7d91ebe9ce652cd3f28befb0e0623271990f99fd..2f8193170aedf3009a9377879a2b4da0c7c11c08 100644
--- a/spec/models/project_services/jira_service_spec.rb
+++ b/spec/models/project_services/jira_service_spec.rb
@@ -26,6 +26,113 @@ describe JiraService, models: true do
     it { is_expected.to have_one :service_hook }
   end
 
+  describe "Execute" do
+    let(:user)    { create(:user) }
+    let(:project) { create(:project) }
+    let(:merge_request) { create(:merge_request) }
+
+    before do
+      @jira_service = JiraService.new
+      allow(@jira_service).to receive_messages(
+        project_id: project.id,
+        project: project,
+        service_hook: true,
+        project_url: 'http://jira.example.com',
+        username: 'gitlab_jira_username',
+        password: 'gitlab_jira_password'
+      )
+      @jira_service.save # will build API URL, as api_url was not specified above
+      @sample_data = Gitlab::PushDataBuilder.build_sample(project, user)
+      # https://github.com/bblimke/webmock#request-with-basic-authentication
+      @api_url = 'http://gitlab_jira_username:gitlab_jira_password@jira.example.com/rest/api/2/issue/JIRA-123/transitions'
+      @comment_url = 'http://gitlab_jira_username:gitlab_jira_password@jira.example.com/rest/api/2/issue/JIRA-123/comment'
+
+      WebMock.stub_request(:post, @api_url)
+      WebMock.stub_request(:post, @comment_url)
+    end
+
+    it "should call JIRA API" do
+      @jira_service.execute(merge_request, JiraIssue.new("JIRA-123", project))
+      expect(WebMock).to have_requested(:post, @comment_url).with(
+        body: /Issue solved with/
+      ).once
+    end
+
+    it "calls the api with jira_issue_transition_id" do
+      @jira_service.jira_issue_transition_id = 'this-is-a-custom-id'
+      @jira_service.execute(merge_request, JiraIssue.new("JIRA-123", project))
+      expect(WebMock).to have_requested(:post, @api_url).with(
+        body: /this-is-a-custom-id/
+      ).once
+    end
+  end
+
+  describe "Stored password invalidation" do
+    let(:project) { create(:project) }
+
+    context "when a password was previously set" do
+      before do
+        @jira_service = JiraService.create(
+          project: create(:project),
+          properties: {
+            api_url: 'http://jira.example.com/rest/api/2',
+            username: 'mic',
+            password: "password"
+          }
+        )
+      end
+
+      it "reset password if url changed" do
+        @jira_service.api_url = 'http://jira_edited.example.com/rest/api/2'
+        @jira_service.save
+        expect(@jira_service.password).to be_nil
+      end
+
+      it "does not reset password if username changed" do
+        @jira_service.username = "some_name"
+        @jira_service.save
+        expect(@jira_service.password).to eq("password")
+      end
+
+      it "does not reset password if new url is set together with password, even if it's the same password" do
+        @jira_service.api_url = 'http://jira_edited.example.com/rest/api/2'
+        @jira_service.password = 'password'
+        @jira_service.save
+        expect(@jira_service.password).to eq("password")
+        expect(@jira_service.api_url).to eq("http://jira_edited.example.com/rest/api/2")
+      end
+
+      it "should reset password if url changed, even if setter called multiple times" do
+        @jira_service.api_url = 'http://jira1.example.com/rest/api/2'
+        @jira_service.api_url = 'http://jira1.example.com/rest/api/2'
+        @jira_service.save
+        expect(@jira_service.password).to be_nil
+      end
+    end
+
+    context "when no password was previously set" do
+      before do
+        @jira_service = JiraService.create(
+          project: create(:project),
+          properties: {
+            api_url: 'http://jira.example.com/rest/api/2',
+            username: 'mic'
+          }
+        )
+      end
+
+      it "saves password if new url is set together with password" do
+        @jira_service.api_url = 'http://jira_edited.example.com/rest/api/2'
+        @jira_service.password = 'password'
+        @jira_service.save
+        expect(@jira_service.password).to eq("password")
+        expect(@jira_service.api_url).to eq("http://jira_edited.example.com/rest/api/2")
+      end
+
+    end
+  end
+
+
   describe "Validations" do
     context "active" do
       before do
@@ -78,11 +185,12 @@ describe JiraService, models: true do
 
     context 'when gitlab.yml was initialized' do
       before do
-        settings = { "jira" => {
-          "title" => "Jira",
-          "project_url" => "http://jira.sample/projects/project_a",
-          "issues_url" => "http://jira.sample/issues/:id",
-          "new_issue_url" => "http://jira.sample/projects/project_a/issues/new"
+        settings = {
+          "jira" => {
+            "title" => "Jira",
+            "project_url" => "http://jira.sample/projects/project_a",
+            "issues_url" => "http://jira.sample/issues/:id",
+            "new_issue_url" => "http://jira.sample/projects/project_a/issues/new"
           }
         }
         allow(Gitlab.config).to receive(:issues_tracker).and_return(settings)
diff --git a/spec/models/project_spec.rb b/spec/models/project_spec.rb
index c4d3813e9c9cdf68706e8e4b1a9a26f6e88122c0..400bdf2d962bcdf35ded86db2715f44aba542fa4 100644
--- a/spec/models/project_spec.rb
+++ b/spec/models/project_spec.rb
@@ -552,4 +552,28 @@ describe Project, models: true do
       end
     end
   end
+
+  describe '#visibility_level_allowed?' do
+    let(:project) { create :project, visibility_level: Gitlab::VisibilityLevel::INTERNAL }
+
+    context 'when checking on non-forked project' do
+      it { expect(project.visibility_level_allowed?(Gitlab::VisibilityLevel::PRIVATE)).to be_truthy }
+      it { expect(project.visibility_level_allowed?(Gitlab::VisibilityLevel::INTERNAL)).to be_truthy }
+      it { expect(project.visibility_level_allowed?(Gitlab::VisibilityLevel::PUBLIC)).to be_truthy }
+    end
+
+    context 'when checking on forked project' do
+      let(:forked_project) { create :forked_project_with_submodules }
+
+      before do
+        forked_project.build_forked_project_link(forked_to_project_id: forked_project.id, forked_from_project_id: project.id)
+        forked_project.save
+      end
+
+      it { expect(forked_project.visibility_level_allowed?(Gitlab::VisibilityLevel::PRIVATE)).to be_truthy }
+      it { expect(forked_project.visibility_level_allowed?(Gitlab::VisibilityLevel::INTERNAL)).to be_truthy }
+      it { expect(forked_project.visibility_level_allowed?(Gitlab::VisibilityLevel::PUBLIC)).to be_falsey }
+    end
+
+  end
 end
diff --git a/spec/models/user_spec.rb b/spec/models/user_spec.rb
index 376266c09559038fe1616c717d536c98b6025bc7..2f184bbaf92c50fffd79529ea173d84a89d50421 100644
--- a/spec/models/user_spec.rb
+++ b/spec/models/user_spec.rb
@@ -26,6 +26,7 @@
 #  bio                        :string(255)
 #  failed_attempts            :integer          default(0)
 #  locked_at                  :datetime
+#  unlock_token               :string(255)
 #  username                   :string(255)
 #  can_create_group           :boolean          default(TRUE), not null
 #  can_create_team            :boolean          default(TRUE), not null
diff --git a/spec/requests/api/branches_spec.rb b/spec/requests/api/branches_spec.rb
index 5c1b58535cc3b636122791e49e27a0e309b3950a..36461e84c3ab7c33283415c82505036c35d1e0d1 100644
--- a/spec/requests/api/branches_spec.rb
+++ b/spec/requests/api/branches_spec.rb
@@ -118,7 +118,7 @@ describe API::API, api: true  do
            branch_name: 'new design',
            ref: branch_sha
       expect(response.status).to eq(400)
-      expect(json_response['message']).to eq('Branch name invalid')
+      expect(json_response['message']).to eq('Branch name is invalid')
     end
 
     it 'should return 400 if branch already exists' do
diff --git a/spec/requests/api/projects_spec.rb b/spec/requests/api/projects_spec.rb
index 01d2ec79482d8349b4b27f3725e435c9aac2669e..7f0f9454b1006a193e5f10470e50857973af4a4b 100644
--- a/spec/requests/api/projects_spec.rb
+++ b/spec/requests/api/projects_spec.rb
@@ -131,6 +131,7 @@ describe API::API, api: true  do
 
         expect(json_response).to satisfy do |response|
           response.one? do |entry|
+            entry.has_key?('permissions') &&
             entry['name'] == project.name &&
               entry['owner']['username'] == user.username
           end
@@ -382,6 +383,18 @@ describe API::API, api: true  do
     end
 
     describe 'permissions' do
+      context 'all projects' do
+        it 'Contains permission information' do
+          project.team << [user, :master]
+          get api("/projects", user)
+
+          expect(response.status).to eq(200)
+          expect(json_response.first['permissions']['project_access']['access_level']).
+              to eq(Gitlab::Access::MASTER)
+          expect(json_response.first['permissions']['group_access']).to be_nil
+        end
+      end
+
       context 'personal project' do
         it 'Sets project access and returns 200' do
           project.team << [user, :master]
diff --git a/spec/requests/ci/api/runners_spec.rb b/spec/requests/ci/api/runners_spec.rb
index 567da013e6f22ac3a6872456c8b51714fe17ebc5..5942aa7a1b59f27cade4f9b0fe08018bd0a76ea4 100644
--- a/spec/requests/ci/api/runners_spec.rb
+++ b/spec/requests/ci/api/runners_spec.rb
@@ -8,7 +8,6 @@ describe Ci::API::API do
 
   before do
     stub_gitlab_calls
-    stub_application_setting(ensure_runners_registration_token: registration_token)
     stub_application_setting(runners_registration_token: registration_token)
   end
 
diff --git a/spec/services/git_push_service_spec.rb b/spec/services/git_push_service_spec.rb
index a04c242cf0e72a26069c7f4735bf74b80e81018b..c1080ef190aa2303641d110aa0d45a99b8fa805d 100644
--- a/spec/services/git_push_service_spec.rb
+++ b/spec/services/git_push_service_spec.rb
@@ -265,6 +265,75 @@ describe GitPushService, services: true do
         expect(Issue.find(issue.id)).to be_opened
       end
     end
+
+    # EE-only tests
+    context "for jira issue tracker" do
+      include JiraServiceHelper
+
+      let(:jira_tracker) { project.create_jira_service if project.jira_service.nil? }
+
+      before do
+        jira_service_settings
+
+        WebMock.stub_request(:post, jira_api_transition_url)
+        WebMock.stub_request(:post, jira_api_comment_url)
+        WebMock.stub_request(:get, jira_api_comment_url).to_return(body: jira_issue_comments)
+        WebMock.stub_request(:get, jira_api_test_url)
+
+        allow(closing_commit).to receive_messages({
+                                                    issue_closing_regex: Regexp.new(Gitlab.config.gitlab.issue_closing_pattern),
+                                                    safe_message: message,
+                                                    author_name: commit_author.name,
+                                                    author_email: commit_author.email
+                                                  })
+
+        allow(project.repository).to receive_messages(commits_between: [closing_commit])
+      end
+
+      after do
+        jira_tracker.destroy!
+      end
+
+      context "mentioning an issue" do
+        let(:message) { "this is some work.\n\nrelated to JIRA-1" }
+
+        it "should initiate one api call to jira server to mention the issue" do
+          service.execute(project, user, @oldrev, @newrev, @ref)
+
+          expect(WebMock).to have_requested(:post, jira_api_comment_url).with(
+            body: /mentioned this issue in/
+          ).once
+        end
+      end
+
+      context "closing an issue" do
+        let(:message) { "this is some work.\n\ncloses JIRA-1" }
+
+        it "should initiate one api call to jira server to close the issue" do
+          transition_body = {
+            transition: {
+              id: '2'
+            }
+          }.to_json
+
+          service.execute(project, user, @oldrev, @newrev, @ref)
+          expect(WebMock).to have_requested(:post, jira_api_transition_url).with(
+            body: transition_body
+          ).once
+        end
+
+        it "should initiate one api call to jira server to comment on the issue" do
+          comment_body = {
+            body: "Issue solved with [#{closing_commit.id}|http://localhost/#{project.path_with_namespace}/commit/#{closing_commit.id}]."
+          }.to_json
+
+          service.execute(project, user, @oldrev, @newrev, @ref)
+          expect(WebMock).to have_requested(:post, jira_api_comment_url).with(
+            body: comment_body
+          ).once
+        end
+      end
+    end
   end
 
   describe "empty project" do
diff --git a/spec/services/projects/update_service_spec.rb b/spec/services/projects/update_service_spec.rb
index c36d45819896a9d78f0bc0911c7e09deb721cf1e..3c06a8901634512a99828a8bfab6144fcfb56a1b 100644
--- a/spec/services/projects/update_service_spec.rb
+++ b/spec/services/projects/update_service_spec.rb
@@ -100,6 +100,45 @@ describe Projects::UpdateService, services: true do
     end
   end
 
+  describe :visibility_level do
+    let(:user) { create :user, admin: true }
+    let(:project) { create :project, visibility_level: Gitlab::VisibilityLevel::INTERNAL }
+    let(:forked_project) { create :forked_project_with_submodules, visibility_level: Gitlab::VisibilityLevel::INTERNAL }
+    let(:opts) { {} }
+
+    before do
+      forked_project.build_forked_project_link(forked_to_project_id: forked_project.id, forked_from_project_id: project.id)
+      forked_project.save
+
+      @created_internal = project.internal?
+      @fork_created_internal = forked_project.internal?
+    end
+
+    context 'should update forks visibility level when parent set to more restrictive' do
+      before do
+        opts.merge!(visibility_level: Gitlab::VisibilityLevel::PRIVATE)
+        update_project(project, user, opts).inspect
+      end
+
+      it { expect(@created_internal).to be_truthy }
+      it { expect(@fork_created_internal).to be_truthy }
+      it { expect(project.private?).to be_truthy }
+      it { expect(project.forks.first.private?).to be_truthy }
+    end
+
+    context 'should not update forks visibility level when parent set to less restrictive' do
+      before do
+        opts.merge!(visibility_level: Gitlab::VisibilityLevel::PUBLIC)
+        update_project(project, user, opts).inspect
+      end
+
+      it { expect(@created_internal).to be_truthy }
+      it { expect(@fork_created_internal).to be_truthy }
+      it { expect(project.public?).to be_truthy }
+      it { expect(project.forks.first.internal?).to be_truthy }
+    end
+  end
+
   def update_project(project, user, opts)
     Projects::UpdateService.new(project, user, opts).execute
   end
diff --git a/spec/services/system_note_service_spec.rb b/spec/services/system_note_service_spec.rb
index 0a4f9b230e890d6b48a528b7a931b01b6853c630..c9f828ae2f7a5e99f63a889e269885b5180e3bef 100644
--- a/spec/services/system_note_service_spec.rb
+++ b/spec/services/system_note_service_spec.rb
@@ -425,4 +425,65 @@ describe SystemNoteService, services: true do
       end
     end
   end
+
+  include JiraServiceHelper
+
+  describe 'JIRA integration' do
+    let(:project)    { create(:project) }
+    let(:author)     { create(:user) }
+    let(:issue)      { create(:issue, project: project) }
+    let(:mergereq)   { create(:merge_request, :simple, target_project: project, source_project: project) }
+    let(:jira_issue) { JiraIssue.new("JIRA-1", project)}
+    let(:jira_tracker) { project.create_jira_service if project.jira_service.nil? }
+    let(:commit)     { project.commit }
+
+    context 'in JIRA issue tracker' do
+      before do
+        jira_service_settings
+        WebMock.stub_request(:post, jira_api_comment_url)
+      end
+
+      after do
+        jira_tracker.destroy!
+      end
+
+      describe "new reference" do
+        before do
+          WebMock.stub_request(:get, jira_api_comment_url).to_return(body: jira_issue_comments)
+        end
+
+        subject { described_class.cross_reference(jira_issue, commit, author) }
+
+        it { is_expected.to eq(jira_status_message) }
+      end
+
+      describe "existing reference" do
+        before do
+          message = "[#{author.name}|http://localhost/u/#{author.username}] mentioned this issue in [a commit of #{project.path_with_namespace}|http://localhost/#{project.path_with_namespace}/commit/#{commit.id}]."
+          WebMock.stub_request(:get, jira_api_comment_url).to_return(body: "{\"comments\":[{\"body\":\"#{message}\"}]}")
+        end
+
+        subject { described_class.cross_reference(jira_issue, commit, author) }
+        it { is_expected.not_to eq(jira_status_message) }
+      end
+    end
+
+    context 'issue from an issue' do
+      context 'in JIRA issue tracker' do
+        before do
+          jira_service_settings
+          WebMock.stub_request(:post, jira_api_comment_url)
+          WebMock.stub_request(:get, jira_api_comment_url).to_return(body: jira_issue_comments)
+        end
+
+        after do
+          jira_tracker.destroy!
+        end
+
+        subject { described_class.cross_reference(jira_issue, issue, author) }
+
+        it { is_expected.to eq(jira_status_message) }
+      end
+    end
+  end
 end
diff --git a/spec/support/jira_service_helper.rb b/spec/support/jira_service_helper.rb
new file mode 100644
index 0000000000000000000000000000000000000000..a3f496359b1675f45aebf946ce24d8b1a7818f87
--- /dev/null
+++ b/spec/support/jira_service_helper.rb
@@ -0,0 +1,67 @@
+module JiraServiceHelper
+
+  def jira_service_settings
+    properties = {
+      "title"=>"JIRA tracker",
+      "project_url"=>"http://jira.example/issues/?jql=project=A",
+      "issues_url"=>"http://jira.example/browse/JIRA-1",
+      "new_issue_url"=>"http://jira.example/secure/CreateIssue.jspa",
+      "api_url"=>"http://jira.example/rest/api/2"
+    }
+
+    jira_tracker.update_attributes(properties: properties, active: true)
+  end
+
+  def jira_status_message
+    "JiraService SUCCESS 200: Successfully posted to #{jira_api_comment_url}."
+  end
+
+  def jira_issue_comments
+    "{\"startAt\":0,\"maxResults\":11,\"total\":11,
+      \"comments\":[{\"self\":\"http://0.0.0.0:4567/rest/api/2/issue/10002/comment/10609\",
+      \"id\":\"10609\",\"author\":{\"self\":\"http://0.0.0.0:4567/rest/api/2/user?username=gitlab\",
+      \"name\":\"gitlab\",\"emailAddress\":\"gitlab@example.com\",
+      \"avatarUrls\":{\"16x16\":\"http://0.0.0.0:4567/secure/useravatar?size=xsmall&avatarId=10122\",
+      \"24x24\":\"http://0.0.0.0:4567/secure/useravatar?size=small&avatarId=10122\",
+      \"32x32\":\"http://0.0.0.0:4567/secure/useravatar?size=medium&avatarId=10122\",
+      \"48x48\":\"http://0.0.0.0:4567/secure/useravatar?avatarId=10122\"},
+      \"displayName\":\"GitLab\",\"active\":true},
+      \"body\":\"[Administrator|http://localhost:3000/u/root] mentioned JIRA-1 in Merge request of [gitlab-org/gitlab-test|http://localhost:3000/gitlab-org/gitlab-test/merge_requests/2].\",
+      \"updateAuthor\":{\"self\":\"http://0.0.0.0:4567/rest/api/2/user?username=gitlab\",\"name\":\"gitlab\",\"emailAddress\":\"gitlab@example.com\",
+      \"avatarUrls\":{\"16x16\":\"http://0.0.0.0:4567/secure/useravatar?size=xsmall&avatarId=10122\",
+      \"24x24\":\"http://0.0.0.0:4567/secure/useravatar?size=small&avatarId=10122\",
+      \"32x32\":\"http://0.0.0.0:4567/secure/useravatar?size=medium&avatarId=10122\",
+      \"48x48\":\"http://0.0.0.0:4567/secure/useravatar?avatarId=10122\"},\"displayName\":\"GitLab\",\"active\":true},
+      \"created\":\"2015-02-12T22:47:07.826+0100\",
+      \"updated\":\"2015-02-12T22:47:07.826+0100\"},
+     {\"self\":\"http://0.0.0.0:4567/rest/api/2/issue/10002/comment/10700\",
+        \"id\":\"10700\",\"author\":{\"self\":\"http://0.0.0.0:4567/rest/api/2/user?username=gitlab\",
+        \"name\":\"gitlab\",\"emailAddress\":\"gitlab@example.com\",
+        \"avatarUrls\":{\"16x16\":\"http://0.0.0.0:4567/secure/useravatar?size=xsmall&avatarId=10122\",
+        \"24x24\":\"http://0.0.0.0:4567/secure/useravatar?size=small&avatarId=10122\",
+        \"32x32\":\"http://0.0.0.0:4567/secure/useravatar?size=medium&avatarId=10122\",
+        \"48x48\":\"http://0.0.0.0:4567/secure/useravatar?avatarId=10122\"},\"displayName\":\"GitLab\",\"active\":true},
+        \"body\":\"[Administrator|http://localhost:3000/u/root] mentioned this issue in [a commit of h5bp/html5-boilerplate|http://localhost:3000/h5bp/html5-boilerplate/commit/2439f77897122fbeee3bfd9bb692d3608848433e].\",
+        \"updateAuthor\":{\"self\":\"http://0.0.0.0:4567/rest/api/2/user?username=gitlab\",\"name\":\"gitlab\",\"emailAddress\":\"gitlab@example.com\",
+        \"avatarUrls\":{\"16x16\":\"http://0.0.0.0:4567/secure/useravatar?size=xsmall&avatarId=10122\",
+        \"24x24\":\"http://0.0.0.0:4567/secure/useravatar?size=small&avatarId=10122\",
+        \"32x32\":\"http://0.0.0.0:4567/secure/useravatar?size=medium&avatarId=10122\",
+        \"48x48\":\"http://0.0.0.0:4567/secure/useravatar?avatarId=10122\"},\"displayName\":\"GitLab\",\"active\":true},
+        \"created\":\"2015-04-01T03:45:55.667+0200\",
+        \"updated\":\"2015-04-01T03:45:55.667+0200\"
+      }
+      ]}"
+  end
+
+  def jira_api_comment_url
+    'http://jira.example/rest/api/2/issue/JIRA-1/comment'
+  end
+
+  def jira_api_transition_url
+    'http://jira.example/rest/api/2/issue/JIRA-1/transitions'
+  end
+
+  def jira_api_test_url
+    'http://jira.example/rest/api/2/myself'
+  end
+end