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#', 'h': 'c', 'hpp': 'cpp', 'cxx': 'cpp'}
  24. # do search-request
  25. def request(query, params):
  26. params['url'] = search_url.format(query=urlencode({'q': query}), 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(), result['filename'].split('.')[-1].lower()
  42. )
  43. # append result
  44. results.append(
  45. {
  46. 'url': href,
  47. 'title': title,
  48. 'content': '',
  49. 'repository': repo,
  50. 'codelines': sorted(lines.items()),
  51. 'code_language': code_language,
  52. 'template': 'code.html',
  53. }
  54. )
  55. # return results
  56. return results