From 60ea7e1b4e6225885b85bb3dd368eeef4de6a31e Mon Sep 17 00:00:00 2001
From: Zeno Albisser <zeno.albisser@digia.com>
Date: Thu, 18 Jul 2013 12:01:59 +0200
Subject: [PATCH] Add a python script to generate the chromium .pak resource
 files.

This is necessary, because the pak files must be available
when qmake checks for the dependencies for RESOURCES in lib.pro.

Change-Id: Ia173c70746402b2fee09bfa035a9f8780e88cc94
Reviewed-by: Andras Becsi <andras.becsi@digia.com>
---
 build/scripts/build_resources.py | 102 +++++++++++++++++++++++++++++++
 lib/lib.pro                      |   3 +-
 lib/lib_resources.qrc            |   4 +-
 qtwebengine.pro                  |   3 +-
 resources/resources.pro          |   7 +++
 5 files changed, 115 insertions(+), 4 deletions(-)
 create mode 100755 build/scripts/build_resources.py
 create mode 100644 resources/resources.pro

diff --git a/build/scripts/build_resources.py b/build/scripts/build_resources.py
new file mode 100755
index 000000000..6dd350fc6
--- /dev/null
+++ b/build/scripts/build_resources.py
@@ -0,0 +1,102 @@
+#!/usr/bin/env python
+
+#############################################################################
+#
+# Copyright (C) 2013 Digia Plc and/or its subsidiary(-ies).
+# Contact: http://www.qt-project.org/legal
+#
+# This file is part of the QtWebEngine module of the Qt Toolkit.
+#
+# $QT_BEGIN_LICENSE:LGPL$
+# Commercial License Usage
+# Licensees holding valid commercial Qt licenses may use this file in
+# accordance with the commercial license agreement provided with the
+# Software or, alternatively, in accordance with the terms contained in
+# a written agreement between you and Digia.  For licensing terms and
+# conditions see http://qt.digia.com/licensing.  For further information
+# use the contact form at http://qt.digia.com/contact-us.
+#
+# GNU Lesser General Public License Usage
+# Alternatively, this file may be used under the terms of the GNU Lesser
+# General Public License version 2.1 as published by the Free Software
+# Foundation and appearing in the file LICENSE.LGPL included in the
+# packaging of this file.  Please review the following information to
+# ensure the GNU Lesser General Public License version 2.1 requirements
+# will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
+#
+# In addition, as a special exception, Digia gives you certain additional
+# rights.  These rights are described in the Digia Qt LGPL Exception
+# version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
+#
+# GNU General Public License Usage
+# Alternatively, this file may be used under the terms of the GNU
+# General Public License version 3.0 as published by the Free Software
+# Foundation and appearing in the file LICENSE.GPL included in the
+# packaging of this file.  Please review the following information to
+# ensure the GNU General Public License version 3.0 requirements will be
+# met: http://www.gnu.org/copyleft/gpl.html.
+#
+#
+# $QT_END_LICENSE$
+#
+#############################################################################
+
+import glob
+import os
+import subprocess
+import sys
+import string
+import time
+
+qtwebengine_src = os.path.abspath(os.path.join(os.path.dirname(__file__), "../.."))
+
+chrome_src = os.environ.get('CHROMIUM_SRC_DIR')
+if chrome_src:
+  chrome_src = os.path.abspath(chrome_src)
+if not chrome_src or not os.path.isdir(chrome_src):
+  chrome_src = os.path.join(qtwebengine_src, 'chromium')
+  print 'CHROMIUM_SRC_DIR not set, falling back to ' + chrome_src
+
+grit_tool = os.path.join(chrome_src, 'tools/grit/grit.py')
+resources_subdir = os.path.join(qtwebengine_src, 'resources')
+
+def checkNeedForRebuild(grd_file):
+    grit_files = subprocess.check_output(['python', grit_tool, '-i', grd_file, 'buildinfo']).splitlines()
+
+    dependencies = [grd_file]
+    data_packages = []
+    for line in grit_files:
+        if line.startswith('input|'):
+            dependencies.append(line.split('|')[1])
+        if line.startswith('data_package|'):
+            data_packages.append(line.split('|')[1])
+
+    target_timestamp = 0
+    for data_package in data_packages:
+        data_package_file = os.path.join(resources_subdir, data_package)
+        if not os.path.isfile(data_package_file):
+            return True
+
+        data_package_timestamp = os.path.getmtime(data_package_file)
+        if data_package_timestamp < target_timestamp or target_timestamp == 0:
+            target_timestamp = data_package_timestamp
+
+    for dependency in dependencies:
+        dependency_timestamp = os.path.getmtime(dependency)
+        if (dependency_timestamp > target_timestamp):
+            return True
+    return False
+
+def rebuildPakFile(grd_file):
+    print 'Rebuilding resource file for:' + grd_file
+    resource_ids_file = os.path.join(chrome_src, 'tools/gritsettings/resource_ids')
+    subprocess.call(['python', grit_tool, '-i', grd_file, 'build', '-f', resource_ids_file, '-o', resources_subdir])
+
+def rebuildIfNeeded(grd_file):
+    grd_file = os.path.join(chrome_src, grd_file)
+    if checkNeedForRebuild(grd_file):
+        rebuildPakFile(grd_file)
+
+
+# The grd_file is specified relative to the chromium source directory.
+rebuildIfNeeded('net/base/net_resources.grd')
diff --git a/lib/lib.pro b/lib/lib.pro
index 45d8675fd..a89129930 100644
--- a/lib/lib.pro
+++ b/lib/lib.pro
@@ -3,7 +3,6 @@
 # our gyp_generator.prf feature to the CONFIG variable since it is processed backwards
 CONFIG = gyp_generator $$CONFIG
 GYPDEPENDENCIES += ../shared/shared.gyp:qtwebengine_shared
-GYPDEPENDENCIES += ../chromium/net/net.gyp:net_resources
 GYPINCLUDES += ../qtwebengine.gypi
 
 TEMPLATE = lib
@@ -22,6 +21,8 @@ CONFIG(release, debug|release): DEFINES += NDEBUG
 QT += widgets quick
 
 RESOURCES += lib_resources.qrc
+# We need this to find the include files generated for the .pak resource files.
+INCLUDEPATH += $$absolute_path(../resources, $$PWD)
 
 SOURCES = \
         backing_store_qt.cpp \
diff --git a/lib/lib_resources.qrc b/lib/lib_resources.qrc
index 4e6fce92a..af8448d2b 100644
--- a/lib/lib_resources.qrc
+++ b/lib/lib_resources.qrc
@@ -1,5 +1,5 @@
 <!DOCTYPE RCC><RCC version="1.0">
 <qresource prefix="data">
-    <file alias="resources.pak">/Users/zeno/work/qtwebengine/out/Release/gen/net/net_resources.pak</file>
+    <file alias="resources.pak">../resources/net_resources.pak</file>
 </qresource>
-</RCC>
\ No newline at end of file
+</RCC>
diff --git a/qtwebengine.pro b/qtwebengine.pro
index ddf013d55..c15cb1919 100644
--- a/qtwebengine.pro
+++ b/qtwebengine.pro
@@ -4,7 +4,8 @@ CONFIG += ordered
 
 # The first three subdirs contain dummy .pro files that are used by qmake
 # to generate a corresponding .gyp file
-SUBDIRS = shared \
+SUBDIRS = resources \
+          shared \
           lib \
           process \
           build \ # This is where we use the generated qt_generated.gypi and run gyp
diff --git a/resources/resources.pro b/resources/resources.pro
new file mode 100644
index 000000000..77d5077c2
--- /dev/null
+++ b/resources/resources.pro
@@ -0,0 +1,7 @@
+# This is a dummy .pro file used to prepare chromium .pak resource files.
+# These files will then be bundled using the Qt Resource System.
+TEMPLATE = subdirs
+
+system(python ../build/scripts/build_resources.py)
+
+
-- 
GitLab