## Searchcode (It) # # @website https://searchcode.com/ # @provide-api yes (https://searchcode.com/api/) # # @using-api yes # @results JSON # @stable yes # @parse url, title, content from urllib import urlencode from json import loads import cgi import re # engine dependent config categories = ['it'] paging = True # search-url url = 'https://searchcode.com/' search_url = url+'api/codesearch_I/?{query}&p={pageno}' # do search-request def request(query, params): params['url'] = search_url.format(query=urlencode({'q': query}), pageno=params['pageno']-1) return params # get response from search-request def response(resp): results = [] search_results = loads(resp.text) # parse results for result in search_results['results']: href = result['url'] title = "" + result['name'] + " - " + result['filename'] content = result['repo'] + "
" lines = dict() for line, code in result['lines'].items(): lines[int(line)] = code content = content + '
'
        for line, code in sorted(lines.items()):
            content = content + '"
            
        content = content + "
' content = content + str(line) + '' # Replace every two spaces with ' &nbps;' to keep formatting while allowing the browser to break the line if necessary content = content + cgi.escape(code).replace('\t', ' ').replace(' ', '  ').replace(' ', '  ') content = content + "
" # append result results.append({'url': href, 'title': title, 'content': content}) # return results return results