# THIS SOFTWARE IS A PART OF FREE COMPETITOR PROJECT # THE FOLLOWING SOURCE CODE I UNDER THE GNU # AGPL LICENSE V3 OR ANY LATER VERSION. # This project is not for simple users, but for # web-masters and a like, so we are counting on # your ability to set it up and running. import os from modules import search def html(page, json): # This function adds a rendering of the json into the page free = search.is_free(json) page = page + "\n

" try: page = page + '\nLogo' except: pass name = json.get("names",["Unknown"])[0] page = page + "\n" + name page = page + "

" # Few words about it comment = json.get("comment","") not_foss = ['open source', 'open-source'] if "open source" or "open-source" in comment.lower(): # Well... Here is a thing. Free Software, not open source. where = comment.lower().find("open source") # In case it has a slash in it. if where == -1: where = comment.lower().find("open-source") ops = comment[where:where+11] comment = comment.replace(ops, ""+ops+"") page = page + "

"+comment+"

" # I want to show nothing else from if it's proprietary issues_files = list(os.listdir("data/issues")) if "issues" in json: l = json.get("issues", []) page = page +"

Anti-Features / Problems:

" for i in l: if i+".html" not in issues_files: page = page + "  "+i+"
" else: page = page + '
' page = page + "  "+i+"" issuefile = open("data/issues/"+i+".html") page = page + "

"+issuefile.read()+"

" page = page + "
" if not free: return page # Links # # # # # # page = page + """ """ page = page + "
CompanyContactCountry
" links = json.get("links", {}) for website in links: if website in ["icon"]: continue link = links[website] page = page + """ """ page = page + "
" # Details categories = {"generic_name":"Features", "licenses":"License(s)", "platforms":"Platforms", "networks_read":"Accesses Data from", "networks_write":"Interacts / Publishes to", "formats_read":"Opens from File-Formats", "formats_write":"Saves to File-Formats", "interface":"Interface", "languages":"Programming Languages"} for c in categories: l = json.get(c, []) if not l: continue page = page + "
" page = page +""+categories[c]+":" for i in l: page = page + "  "+i+"
" page = page + "
" return page def suggestions(page, json): # This function will render suggestions page = page + "

Free Competitors:

" found = search.suggest(json) biggest = 0 for i in found: if i[0] > biggest: biggest = i[0] more = False for i in found: free = search.is_free(i[-1]) if not i[0] or i[-1] == json or not free: continue try: frac = int(i[0]/biggest*100) except: frac = 0 if frac < 40 and not more: # Below 40% features match page = page + """

Problematic Competitors:

""" more = True page = page + "

Suggestion score: " + str(frac) + "%" page = html(page, i[-1]) if more: page = page + "
" return page def search_widget(page, address): # Adds a search bar to the page page = page + """
""" #page = page.format(ADDRESS) return page def source_code_link(page): # Adds a source code link page = page + "


This website is under the GNU AGPL license.

" page = page + """


""" return page