searchcode_code.py 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. ## Searchcode (It)
  2. #
  3. # @website https://searchcode.com/
  4. # @provide-api yes (https://searchcode.com/api/)
  5. #
  6. # @using-api yes
  7. # @results JSON
  8. # @stable yes
  9. # @parse url, title, content
  10. from urllib import urlencode
  11. from json import loads
  12. import cgi
  13. import re
  14. # engine dependent config
  15. categories = ['it']
  16. paging = True
  17. # search-url
  18. url = 'https://searchcode.com/'
  19. search_url = url+'api/codesearch_I/?{query}&p={pageno}'
  20. code_endings = {'c': 'c',
  21. 'css': 'css',
  22. 'cpp': 'cpp',
  23. 'c++': 'cpp',
  24. 'h': 'c',
  25. 'html': 'html',
  26. 'hpp': 'cpp',
  27. 'js': 'js',
  28. 'lua': 'lua',
  29. 'php': 'php',
  30. 'py': 'python'}
  31. # do search-request
  32. def request(query, params):
  33. params['url'] = search_url.format(query=urlencode({'q': query}),
  34. pageno=params['pageno']-1)
  35. return params
  36. # get response from search-request
  37. def response(resp):
  38. results = []
  39. search_results = loads(resp.text)
  40. # parse results
  41. for result in search_results['results']:
  42. href = result['url']
  43. title = "" + result['name'] + " - " + result['filename']
  44. repo = result['repo']
  45. lines = dict()
  46. for line, code in result['lines'].items():
  47. lines[int(line)] = code
  48. code_language = code_endings.get(result['filename'].split('.')[-1].lower(), None)
  49. # append result
  50. results.append({'url': href,
  51. 'title': title,
  52. 'content': '',
  53. 'repository': repo,
  54. 'codelines': sorted(lines.items()),
  55. 'code_language': code_language,
  56. 'template': 'code.html'})
  57. # return results
  58. return results