searchcode_code.py 1.7 KB

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