diff options
| author | Adam Stankiewicz <sheerun@sher.pl> | 2020-10-04 21:17:06 +0200 | 
|---|---|---|
| committer | Adam Stankiewicz <sheerun@sher.pl> | 2020-10-04 21:17:06 +0200 | 
| commit | b4868c7ea7b75dd09a6d172871c901905f5d539a (patch) | |
| tree | 23f20821b10163083aa5c0b2016bce1db28ccc91 /scripts/build | |
| parent | d221139bd70fd474be52237dc8e6440e6da632bd (diff) | |
| download | vim-polyglot-b4868c7ea7b75dd09a6d172871c901905f5d539a.tar.gz vim-polyglot-b4868c7ea7b75dd09a6d172871c901905f5d539a.zip | |
Add comments for some extensions + test
Diffstat (limited to 'scripts/build')
| -rwxr-xr-x | scripts/build | 78 | 
1 files changed, 50 insertions, 28 deletions
| diff --git a/scripts/build b/scripts/build index fe07db70..948da115 100755 --- a/scripts/build +++ b/scripts/build @@ -43,6 +43,18 @@ def verify(packages, heuristics)        puts "No heuristics for .#{e} extension (#{names.join(", ")})"      end    end + +  extensions = packages.flat_map { |e| e["filetypes"] || [] } +    .flat_map { |e| e["extensions"].map { |e| "*." + e } } +  native_filetypes = detect_filetypes_str( +    File.read('ftdetect/polyglot.vim').match(/" DO NOT EDIT CODE ABOVE.*/m)[0] +  ).flat_map { |e| expand_all(e) } + +  for e in (native_filetypes & extensions) +    if ENV["DEV"] +      puts "Duplicated handling for #{e}" +    end +  end  end  def sort_packages(packages) @@ -506,10 +518,12 @@ def generate_ftdetect(packages, heuristics)    for package in packages.reverse      filetypes = package["filetypes"] or raise "Unknown filetype for: #{package["name"]}" -    package_heuristics = [] +    package_autocommands = [] -    autocommands = []      for filetype in filetypes +      autocommands = [] +      filetype_heuristics = [] +        name = filetype.fetch("name")        syntax = filetype["syntax"] ? " | set syntax=#{filetype["syntax"]}" : "" @@ -531,13 +545,13 @@ def generate_ftdetect(packages, heuristics)        for extension in extensions.sort          outer_filetype = filetype["outer_filetype"]          if outer_filetype -          autocommands << "  au BufNewFile *.*.#{extension} execute \"do BufNewFile filetypedetect \" . expand(\"<afile>:r\") | #{outer_filetype}\n" -          autocommands << "  au BufReadPre *.*.#{extension} execute \"do BufRead filetypedetect \" . expand(\"<afile>:r\") | #{outer_filetype}\n" +          autocommands << "au BufNewFile *.*.#{extension} execute \"do BufNewFile filetypedetect \" . expand(\"<afile>:r\") | #{outer_filetype}" +          autocommands << "au BufReadPre *.*.#{extension} execute \"do BufRead filetypedetect \" . expand(\"<afile>:r\") | #{outer_filetype}"          end          heuristic = heuristics.find { |h| h["extensions"].include?(extension) }          if heuristic -          package_heuristics << heuristic +          filetype_heuristics << heuristic          else            set_globs << "*." + extension          end @@ -548,28 +562,34 @@ def generate_ftdetect(packages, heuristics)            filename = "{.,}" + filename[1..-1]          end          if filename[-1] == "*" -          autocommands << "  au BufNewFile,BufRead #{filename} call s:StarSetf('#{name}')\n" +          autocommands << "au BufNewFile,BufRead #{filename} call s:StarSetf('#{name}')"          else            set_globs << filename          end        end        if set_globs.size > 0 -        autocommands << "  au BufNewFile,BufRead #{set_globs.join(",")} #{set_command}\n" +        autocommands << "au BufNewFile,BufRead #{set_globs.join(",")} #{set_command}"        end -    end +      for heuristic in filetype_heuristics.uniq +        extensions = heuristic["extensions"].map { |e| "*.#{e}" } +        autocommands << "au! BufNewFile,BufRead,BufWritePost #{extensions.join(",")} call polyglot#detect##{camelize(heuristic["extensions"].first)}()" +      end -    for heuristic in package_heuristics.uniq -      extensions = heuristic["extensions"].map { |e| "*.#{e}" } -      autocommands << "  au! BufNewFile,BufRead,BufWritePost #{extensions.join(",")} call polyglot#detect##{camelize(heuristic["extensions"].first)}()\n" +      if autocommands.size > 0 && filetype["description"] +        autocommands << '" ' + filetype["description"] +      end + +      package_autocommands << autocommands      end -    if autocommands != "" +    if package_autocommands.flatten.size > 0        output << "if !has_key(s:disabled_packages, '#{package["name"]}')\n" -      output << autocommands.reverse.join("") -      output << "endif\n\n" +      output << indent(package_autocommands.map { |pc| pc.reverse.join("\n") }.join("\n\n"), 2) +      output << "\nendif\n\n"      end +    end    show_warnings(all_filetypes, expected_filetypes) @@ -701,21 +721,23 @@ def expand_all(pattern, all = false)    end  end +def detect_filetypes_str(contents) +  contents = contents.gsub(/^\s*au(tocmd)?!?\s*$/, '') +  results = contents.scan(/^\s*(?:au!|au|au[^g][^ ]*) +(?:\S+)\s+(\S+)[\s\\]+([^\n]+)/) +  results = results.map do |a, b| +    [ +      a, +      b.gsub(/call (?:s:setf|s:StarSetf)\('([^']+)'\)/i, 'setf \1') +      .gsub(/set(?:local)?\s+(?:ft|filetype)=(\S+)/, 'setf \1') +      .gsub(/setf\S*/, 'setf') +      .gsub(/.*setf\s+(\S+).*/, 'setf \1') +    ] +  end.select { |a, b| b.match(/setf \S+/) }.map { |a, b| [a, b.split(" ")[1]] } +  results +end +  def detect_filetypes(glob) -  filetypes = Dir[glob].flat_map do |file| -    contents = File.read(file).gsub(/^\s*au(tocmd)?!?\s*$/, '') -    results = contents.scan(/^\s*(?:au!|au|au[^g][^ ]*) +(?:\S+)\s+(\S+)[\s\\]+([^\n]+)/) -    results = results.map do |a, b| -      [ -        a, -        b.gsub(/call (?:s:setf|s:StarSetf)\('([^']+)'\)/i, 'setf \1') -          .gsub(/set(?:local)?\s+(?:ft|filetype)=(\S+)/, 'setf \1') -        .gsub(/setf\S*/, 'setf') -        .gsub(/.*setf\s+(\S+).*/, 'setf \1') -      ] -    end.select { |a, b| b.match(/setf \S+/) }.map { |a, b| [a, b.split(" ")[1]] } -    results -  end +  filetypes = Dir[glob].flat_map { |file| detect_filetypes_str(File.read(file)) }    filetypes.flat_map do |ext, filetype|      expand_all(ext).map { |e| [filetype, e] } | 
