summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorDmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>2012-03-13 21:07:30 +0200
committerDmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>2012-03-13 21:07:30 +0200
commit0fe36374d88005379001460a74dc4d6359a35d16 (patch)
tree296bb7c6d8f998f47f7e9842805466ef19118c3b /lib
parentb73a33ed4de67167572bb000b369acb991bf8ec2 (diff)
downloadgitlab-ce-0fe36374d88005379001460a74dc4d6359a35d16.tar.gz
Better language detection
Diffstat (limited to 'lib')
-rw-r--r--lib/utils.rb38
1 files changed, 9 insertions, 29 deletions
diff --git a/lib/utils.rb b/lib/utils.rb
index 82463f9ec0c..52f3ee2e195 100644
--- a/lib/utils.rb
+++ b/lib/utils.rb
@@ -22,40 +22,20 @@ module Utils
end
def system_colorize(data, file_name)
+ options = { :encoding => 'utf-8', :linenos => 'True' }
+
+ # Try detect language with pygments
+ Pygments.highlight data, :filename => file_name, :options => options
+ rescue
+ # if it fails use manual detection
ft = handle_file_type(file_name)
- Pygments.highlight(data, :lexer => ft, :options => { :encoding => 'utf-8', :linenos => 'True' })
+ Pygments.highlight(data, :lexer => ft, :options => options)
end
- def handle_file_type(file_name, mime_type = nil)
+ def handle_file_type(file_name)
case file_name
- when /(\.pl|\.scala|\.java|\.haml|\.jade|\.scaml|\.html|\.sass|\.scss|\.php|\.erb)$/
- $1[1..-1].to_sym
- when /(\.c|\.h|\.idc)$/
- :c
- when /(\.cpp|\.hpp|\.c++|\.h++|\.cc|\.hh|\.cxx|\.hxx)$/
- :cpp
- when /(\.d|\.di)$/
- :d
- when /(\.hs|\.lhs)$/
- :haskell
- when /(\.rb|\.ru|\.rake|Rakefile|\.gemspec|\.rbx|Gemfile)$/
+ when /(\.ru|Gemfile)$/
:ruby
- when /(\.py|\.pyw|\.sc|SConstruct|SConscript|\.tac)$/
- :python
- when /(\.js|\.json)$/
- :javascript
- when /(\.xml|\.xsl|\.rss|\.xslt|\.xsd|\.wsdl)$/
- :xml
- when /(\.vm|\.fhtml)$/
- :velocity
- when /\.sh$/
- :bash
- when /\.coffee$/
- :coffeescript
- when /(\.yml|\.yaml)$/
- :yaml
- when /\.md$/
- :minid
else
:text
end