searchcode_code.py 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  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. # engine dependent config
  14. categories = ['it']
  15. paging = True
  16. # search-url
  17. url = 'https://searchcode.com/'
  18. search_url = url+'api/codesearch_I/?{query}&p={pageno}'
  19. # do search-request
  20. def request(query, params):
  21. params['url'] = search_url.format(query=urlencode({'q': query}),
  22. pageno=params['pageno']-1)
  23. return params
  24. # get response from search-request
  25. def response(resp):
  26. results = []
  27. search_results = loads(resp.text)
  28. # parse results
  29. for result in search_results['results']:
  30. href = result['url']
  31. title = "" + result['name'] + " - " + result['filename']
  32. content = result['repo'] + "<br />"
  33. lines = dict()
  34. for line, code in result['lines'].items():
  35. lines[int(line)] = code
  36. content = content + '<pre class="code-formatter"><table class="code">'
  37. for line, code in sorted(lines.items()):
  38. content = content + '<tr><td class="line-number" style="padding-right:5px;">'
  39. content = content + str(line) + '</td><td class="code-snippet">'
  40. # Replace every two spaces with ' &nbps;' to keep formatting
  41. # while allowing the browser to break the line if necessary
  42. content = content + cgi.escape(code).replace('\t', ' ').replace(' ', '&nbsp; ').replace(' ', ' &nbsp;')
  43. content = content + "</td></tr>"
  44. content = content + "</table></pre>"
  45. # append result
  46. results.append({'url': href,
  47. 'title': title,
  48. 'content': content})
  49. # return results
  50. return results