## 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 + '
| ' 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 + " |