searchcode_code.py 1.8 KB

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