#!/usr/bin/env python

Import('env')
env.editor_sources = []

import os
from compat import encode_utf8, byte_to_str, open_utf8


def make_certs_header(target, source, env):

    src = source[0].srcnode().abspath
    dst = target[0].srcnode().abspath
    f = open(src, "rb")
    g = open_utf8(dst, "w")
    buf = f.read()
    decomp_size = len(buf)
    import zlib
    buf = zlib.compress(buf)

    g.write("/* THIS FILE IS GENERATED DO NOT EDIT */\n")
    g.write("#ifndef _CERTS_RAW_H\n")
    g.write("#define _CERTS_RAW_H\n")
    g.write("static const int _certs_compressed_size=" + str(len(buf)) + ";\n")
    g.write("static const int _certs_uncompressed_size=" + str(decomp_size) + ";\n")
    g.write("static const unsigned char _certs_compressed[]={\n")
    for i in range(len(buf)):
        g.write(byte_to_str(buf[i]) + ",\n")
    g.write("};\n")
    g.write("#endif")


def make_doc_header(target, source, env):

    dst = target[0].srcnode().abspath
    g = open_utf8(dst, "w")
    buf = ""
    docbegin = ""
    docend = ""
    for s in source:
        src = s.srcnode().abspath
        f = open_utf8(src, "r")
        content = f.read()
        buf += content[content.find("<class"): content.rfind("</doc>")]
        if len(docbegin) == 0:
            docbegin = content[0: content.find("<class")]
        if len(docend) == 0:
            docend = content[content.rfind("</doc>"): len(buf)]
    buf = encode_utf8(docbegin + buf + docend)
    decomp_size = len(buf)
    import zlib
    buf = zlib.compress(buf)

    g.write("/* THIS FILE IS GENERATED DO NOT EDIT */\n")
    g.write("#ifndef _DOC_DATA_RAW_H\n")
    g.write("#define _DOC_DATA_RAW_H\n")
    g.write("static const int _doc_data_compressed_size=" + str(len(buf)) + ";\n")
    g.write("static const int _doc_data_uncompressed_size=" + str(decomp_size) + ";\n")
    g.write("static const unsigned char _doc_data_compressed[]={\n")
    for i in range(len(buf)):
        g.write(byte_to_str(buf[i]) + ",\n")
    g.write("};\n")
    g.write("#endif")


def make_fonts_header(target, source, env):

    dst = target[0].srcnode().abspath

    g = open_utf8(dst, "w")

    g.write("/* THIS FILE IS GENERATED DO NOT EDIT */\n")
    g.write("#ifndef _EDITOR_FONTS_H\n")
    g.write("#define _EDITOR_FONTS_H\n")

    # saving uncompressed, since freetype will reference from memory pointer
    xl_names = []
    for i in range(len(source)):
        f = open(source[i].srcnode().abspath, "rb")
        buf = f.read()
        import os.path

        name = os.path.splitext(os.path.basename(source[i].srcnode().abspath))[0]

        g.write("static const int _font_" + name + "_size=" + str(len(buf)) + ";\n")
        g.write("static const unsigned char _font_" + name + "[]={\n")
        for i in range(len(buf)):
            g.write(byte_to_str(buf[i]) + ",\n")

        g.write("};\n")

    g.write("#endif")


def make_translations_header(target, source, env):

    dst = target[0].srcnode().abspath

    g = open_utf8(dst, "w")

    g.write("/* THIS FILE IS GENERATED DO NOT EDIT */\n")
    g.write("#ifndef _EDITOR_TRANSLATIONS_H\n")
    g.write("#define _EDITOR_TRANSLATIONS_H\n")

    import zlib
    import os.path

    paths = [node.srcnode().abspath for node in source]
    sorted_paths = sorted(paths, key=lambda path: os.path.splitext(os.path.basename(path))[0])

    xl_names = []
    for i in range(len(sorted_paths)):
        f = open(sorted_paths[i], "rb")
        buf = f.read()
        decomp_size = len(buf)
        buf = zlib.compress(buf)
        name = os.path.splitext(os.path.basename(sorted_paths[i]))[0]

        #g.write("static const int _translation_"+name+"_compressed_size="+str(len(buf))+";\n")
        #g.write("static const int _translation_"+name+"_uncompressed_size="+str(decomp_size)+";\n")
        g.write("static const unsigned char _translation_" + name + "_compressed[]={\n")
        for i in range(len(buf)):
            g.write(byte_to_str(buf[i]) + ",\n")

        g.write("};\n")

        xl_names.append([name, len(buf), str(decomp_size)])

    g.write("struct EditorTranslationList {\n")
    g.write("\tconst char* lang;\n")
    g.write("\tint comp_size;\n")
    g.write("\tint uncomp_size;\n")
    g.write("\tconst unsigned char* data;\n")
    g.write("};\n\n")
    g.write("static EditorTranslationList _editor_translations[]={\n")
    for x in xl_names:
        g.write("\t{ \"" + x[0] + "\", " + str(x[1]) + ", " + str(x[2]) + ",_translation_" + x[0] + "_compressed},\n")
    g.write("\t{NULL,0,0,NULL}\n")
    g.write("};\n")

    g.write("#endif")

def make_authors_header(target, source, env):

    sections = ["Project Founders", "Lead Developer", "Project Manager", "Developers"]
    sections_id = ["dev_founders", "dev_lead", "dev_manager", "dev_names"]

    src = source[0].srcnode().abspath
    dst = target[0].srcnode().abspath
    f = open_utf8(src, "r")
    g = open_utf8(dst, "w")

    g.write("/* THIS FILE IS GENERATED DO NOT EDIT */\n")
    g.write("#ifndef _EDITOR_AUTHORS_H\n")
    g.write("#define _EDITOR_AUTHORS_H\n")

    current_section = ""
    name_count = -1

    def close_section():
        g.write("\t0\n")
        g.write("};\n")
        g.write("#define " + current_section.upper() + "_COUNT " + str(name_count) + "\n")

    for line in f:
        if name_count >= 0:
            if line.startswith("    "):
                g.write("\t\"" + line.strip() + "\",\n")
                name_count += 1
                continue
        if line.startswith("## "):
            if name_count >= 0:
                close_section()
                name_count = -1
            for i in range(len(sections)):
                if line.strip().endswith(sections[i]):
                    current_section = sections_id[i]
                    name_count = 0
                    g.write("static const char *" + current_section + "[] = {\n")
                    break

    if name_count >= 0:
        close_section()

    g.write("#endif\n")

def make_license_header(target, source, env):

    src_copyright = source[0].srcnode().abspath
    src_license = source[1].srcnode().abspath
    dst = target[0].srcnode().abspath
    f = open_utf8(src_license, "r")
    fc = open_utf8(src_copyright, "r")
    g = open_utf8(dst, "w")

    g.write("/* THIS FILE IS GENERATED DO NOT EDIT */\n")
    g.write("#ifndef _EDITOR_LICENSE_H\n")
    g.write("#define _EDITOR_LICENSE_H\n")
    g.write("static const char *about_license =")

    for line in f:
        g.write("\n\t\"" + line.strip().replace("\"", "\\\"") + "\\n\"")

    g.write(";\n")

    tp_current = 0
    tp_file = ""
    tp_comment = ""
    tp_copyright = ""
    tp_license = ""

    tp_licensename = ""
    tp_licensebody = ""

    tp = []
    tp_licensetext = []
    for line in fc:
        if line.startswith("#"):
            continue

        if line.startswith("Files:"):
            tp_file = line[6:].strip()
            tp_current = 1
        elif line.startswith("Comment:"):
            tp_comment = line[8:].strip()
            tp_current = 2
        elif line.startswith("Copyright:"):
            tp_copyright = line[10:].strip()
            tp_current = 3
        elif line.startswith("License:"):
            if tp_current != 0:
                tp_license = line[8:].strip()
                tp_current = 4
            else:
                tp_licensename = line[8:].strip()
                tp_current = 5
        elif line.startswith(" "):
            if tp_current == 1:
                tp_file += "\n" + line.strip()
            elif tp_current == 3:
                tp_copyright += "\n" + line.strip()
            elif tp_current == 5:
                if line.strip() == ".":
                    tp_licensebody += "\n"
                else:
                    tp_licensebody += line[1:]
        else:
            if tp_current != 0:
                if tp_current == 5:
                    tp_licensetext.append([tp_licensename, tp_licensebody])

                    tp_licensename = ""
                    tp_licensebody = ""
                else:
                    added = False
                    for i in tp:
                        if i[0] == tp_comment:
                            i[1].append([tp_file, tp_copyright, tp_license])
                            added = True
                            break
                    if not added:
                        tp.append([tp_comment,[[tp_file, tp_copyright, tp_license]]])

                    tp_file = []
                    tp_comment = ""
                    tp_copyright = []
                    tp_license = ""
                tp_current = 0

    tp_licensetext.append([tp_licensename, tp_licensebody])

    about_thirdparty = ""
    about_tp_copyright_count = ""
    about_tp_license = ""
    about_tp_copyright = ""
    about_tp_file = ""

    for i in tp:
        about_thirdparty += "\t\"" + i[0] + "\",\n"
        about_tp_copyright_count += str(len(i[1])) + ", "
        for j in i[1]:
            file_body = ""
            copyright_body = ""
            for k in j[0].split("\n"):
                if file_body != "":
                    file_body += "\\n\"\n"
                file_body += "\t\"" + k.strip().replace("\"", "\\\"")
            for k in j[1].split("\n"):
                if copyright_body != "":
                    copyright_body += "\\n\"\n"
                copyright_body += "\t\"" + k.strip().replace("\"", "\\\"")

            about_tp_file += "\t" + file_body + "\",\n"
            about_tp_copyright += "\t" + copyright_body + "\",\n"
            about_tp_license += "\t\"" + j[2] + "\",\n"

    about_license_name = ""
    about_license_body = ""

    for i in tp_licensetext:
        body = ""
        for j in i[1].split("\n"):
            if body != "":
                body += "\\n\"\n"
            body += "\t\"" + j.strip().replace("\"", "\\\"")

        about_license_name += "\t\"" + i[0] + "\",\n"
        about_license_body += "\t" + body + "\",\n"

    g.write("static const char *about_thirdparty[] = {\n")
    g.write(about_thirdparty)
    g.write("\t0\n")
    g.write("};\n")
    g.write("#define THIRDPARTY_COUNT " + str(len(tp)) + "\n")

    g.write("static const int about_tp_copyright_count[] = {\n\t")
    g.write(about_tp_copyright_count)
    g.write("0\n};\n")

    g.write("static const char *about_tp_file[] = {\n")
    g.write(about_tp_file)
    g.write("\t0\n")
    g.write("};\n")

    g.write("static const char *about_tp_copyright[] = {\n")
    g.write(about_tp_copyright)
    g.write("\t0\n")
    g.write("};\n")

    g.write("static const char *about_tp_license[] = {\n")
    g.write(about_tp_license)
    g.write("\t0\n")
    g.write("};\n")

    g.write("static const char *about_license_name[] = {\n")
    g.write(about_license_name)
    g.write("\t0\n")
    g.write("};\n")
    g.write("#define LICENSE_COUNT " + str(len(tp_licensetext)) + "\n")

    g.write("static const char *about_license_body[] = {\n")
    g.write(about_license_body)
    g.write("\t0\n")
    g.write("};\n")

    g.write("#endif\n")

if (env["tools"] == "yes"):

    # Register exporters
    reg_exporters_inc = '#include "register_exporters.h"\n'
    reg_exporters = 'void register_exporters() {\n'
    for e in env.platform_exporters:
        env.editor_sources.append("#platform/" + e + "/export/export.cpp")
        reg_exporters += '\tregister_' + e + '_exporter();\n'
        reg_exporters_inc += '#include "platform/' + e + '/export/export.h"\n'
    reg_exporters += '}\n'
    f = open_utf8("register_exporters.gen.cpp", "w")
    f.write(reg_exporters_inc)
    f.write(reg_exporters)
    f.close()

    # API documentation
    docs = ["#doc/base/classes.xml"]
    moduledir = os.path.join(os.getcwd(), "..", "modules")
    for m in os.listdir(moduledir):
        curmodle = os.path.join(moduledir, m)
        docfile = os.path.join(curmodle, "classes.xml")
        if os.path.isdir(curmodle) and os.path.isfile(docfile):
            docs.append(docfile)
    env.Depends("#editor/doc_data_compressed.gen.h", docs)
    env.Command("#editor/doc_data_compressed.gen.h", docs, make_doc_header)

    # Certificates
    env.Depends("#editor/certs_compressed.gen.h", "#thirdparty/certs/ca-certificates.crt")
    env.Command("#editor/certs_compressed.gen.h", "#thirdparty/certs/ca-certificates.crt", make_certs_header)

    import glob
    path = env.Dir('.').abspath

    # Translations
    tlist = glob.glob(path + "/translations/*.po")
    env.Depends('#editor/translations.gen.h', tlist)
    env.Command('#editor/translations.gen.h', tlist, make_translations_header)

    # Fonts
    flist = glob.glob(path + "/../thirdparty/fonts/*.ttf")
    flist.append(glob.glob(path + "/../thirdparty/fonts/*.otf"))
    env.Depends('#editor/builtin_fonts.gen.h', flist)
    env.Command('#editor/builtin_fonts.gen.h', flist, make_fonts_header)

    # Authors
    env.Depends('#editor/authors.gen.h', "../AUTHORS.md")
    env.Command('#editor/authors.gen.h', "../AUTHORS.md", make_authors_header)

    # License
    env.Depends('#editor/license.gen.h', ["../COPYRIGHT.txt", "../LICENSE.txt"])
    env.Command('#editor/license.gen.h', ["../COPYRIGHT.txt", "../LICENSE.txt"], make_license_header)


    env.add_source_files(env.editor_sources, "*.cpp")

    SConscript('collada/SCsub')
    SConscript('doc/SCsub')
    SConscript('fileserver/SCsub')
    SConscript('icons/SCsub')
    SConscript('import/SCsub')
    SConscript('plugins/SCsub')

    lib = env.Library("editor", env.editor_sources)
    env.Prepend(LIBS=[lib])

    Export('env')
