summaryrefslogtreecommitdiffstats
path: root/build
diff options
context:
space:
mode:
authorHenri Sara <henri.sara@itmill.com>2011-07-29 08:13:17 +0000
committerHenri Sara <henri.sara@itmill.com>2011-07-29 08:13:17 +0000
commit5c6aa674102a39af0388d6494c752c1cba4a11e1 (patch)
tree7bb338eda9f66527abce23da19eff151bf8feae4 /build
parente03ef4cc2db66d0904e323dfc660bd18eb450abb (diff)
downloadvaadin-framework-5c6aa674102a39af0388d6494c752c1cba4a11e1.tar.gz
vaadin-framework-5c6aa674102a39af0388d6494c752c1cba4a11e1.zip
#4580 and #7053 theme compiler support for multi-level imports and relative URL processing (needed for Chameleon)
svn changeset:20018/svn branch:6.7
Diffstat (limited to 'build')
-rw-r--r--build/buildhelpers/com/vaadin/buildhelpers/CompileDefaultTheme.java65
1 files changed, 47 insertions, 18 deletions
diff --git a/build/buildhelpers/com/vaadin/buildhelpers/CompileDefaultTheme.java b/build/buildhelpers/com/vaadin/buildhelpers/CompileDefaultTheme.java
index eab61315a1..dd4e1c75ac 100644
--- a/build/buildhelpers/com/vaadin/buildhelpers/CompileDefaultTheme.java
+++ b/build/buildhelpers/com/vaadin/buildhelpers/CompileDefaultTheme.java
@@ -144,13 +144,22 @@ public class CompileDefaultTheme {
if (strLine.startsWith("@import")) {
// All import statements must be exactly
// @import "file-to-import.css";
- // No sub-directories are allowed in the url
+ // or
+ // @import "subdir1[/subdir2]*/file-to-import.css"
+ // ".." and other similar paths are not allowed in the url
String importFilename = strLine.split("\"")[1];
File importFile = new File(THEME_DIR + themeName + "/"
+ folder + "/" + importFilename);
if (importFile.isFile()) {
- processCSSFile(importFile, folder, themeName,
+ String currentFolder = folder;
+ if (importFilename.contains("/")) {
+ currentFolder = currentFolder
+ + "/"
+ + importFilename.substring(0,
+ importFilename.lastIndexOf("/"));
+ }
+ processCSSFile(importFile, currentFolder, themeName,
combinedCss, inheritedFile);
} else {
System.out
@@ -163,23 +172,8 @@ public class CompileDefaultTheme {
}
}
- // Define image url prefix
- String urlPrefix = "";
- if (inheritedFile) {
- urlPrefix = "../" + themeName + "/";
- }
-
- if (strLine.indexOf("url(/") > 0) {
- // Do nothing for urls beginning with /
- } else if (strLine.indexOf("url(../") > 0) {
- strLine = strLine.replaceAll("url\\(../",
- ("url\\(" + urlPrefix));
+ strLine = updateUrls(folder, themeName, inheritedFile, strLine);
- } else {
- strLine = strLine.replaceAll("url\\(", ("url\\("
- + urlPrefix + folder + "/"));
-
- }
if (!strLine.startsWith("@import")) {
combinedCss.append(strLine);
combinedCss.append("\n");
@@ -190,6 +184,41 @@ public class CompileDefaultTheme {
}
}
+ private static String updateUrls(String folder, String themeName,
+ boolean inheritedFile, String strLine) {
+ // Define image url prefix
+ String urlPrefix = "";
+ if (inheritedFile) {
+ urlPrefix = "../" + themeName + "/";
+ }
+
+ if (strLine.indexOf("url(/") > 0) {
+ // Do nothing for urls beginning with /
+ } else if (strLine.indexOf("url(../") >= 0) {
+ // eliminate a path segment in the folder name for every
+ // "../"
+ String[] folderSegments = folder.split("/");
+ int segmentCount = folderSegments.length;
+ while (segmentCount > 0 && strLine.indexOf("url(../") >= 0) {
+ segmentCount--;
+ strLine = strLine.replaceAll("url\\(../", ("url\\("));
+ }
+ // add remaining path segments to urlPrefix
+ StringBuilder sb = new StringBuilder(urlPrefix);
+ for (int i = 0; i < segmentCount; i++) {
+ sb.append(folderSegments[i]);
+ sb.append("/");
+ }
+ strLine = strLine.replaceAll("url\\(", ("url\\(" + sb.toString()));
+
+ } else {
+ strLine = strLine.replaceAll("url\\(", ("url\\(" + urlPrefix
+ + folder + "/"));
+
+ }
+ return strLine;
+ }
+
private static void createSprites(String themeName)
throws FileNotFoundException, IOException {
String[] parameters = new String[] { "--sprite-png-depth", "AUTO",