summaryrefslogtreecommitdiff
path: root/render
diff options
context:
space:
mode:
authorJames Bursa <james@netsurf-browser.org>2002-10-12 13:05:16 +0000
committerJames Bursa <james@netsurf-browser.org>2002-10-12 13:05:16 +0000
commitf459052ef8d42041d582113cbf62cfe8912ebc1a (patch)
treed1192f8939bc1daa92c6a2f9fe4b0cdf6a2684e7 /render
parent390fb8fb8dd559e2efbdaf7a19be9d2faa4042e2 (diff)
downloadnetsurf-f459052ef8d42041d582113cbf62cfe8912ebc1a.tar.gz
netsurf-f459052ef8d42041d582113cbf62cfe8912ebc1a.tar.bz2
[project @ 2002-10-12 13:05:16 by bursa]
Speed improvements in layout_line() (call Font_ScanString much less). svn path=/import/netsurf/; revision=43
Diffstat (limited to 'render')
-rw-r--r--render/layout.c16
1 files changed, 5 insertions, 11 deletions
diff --git a/render/layout.c b/render/layout.c
index f9e29bb90..07e848f5a 100644
--- a/render/layout.c
+++ b/render/layout.c
@@ -1,5 +1,5 @@
/**
- * $Id: layout.c,v 1.20 2002/10/08 09:38:29 bursa Exp $
+ * $Id: layout.c,v 1.21 2002/10/12 13:05:16 bursa Exp $
*/
#include <assert.h>
@@ -13,6 +13,7 @@
#include "netsurf/render/box.h"
#include "netsurf/render/utils.h"
#include "netsurf/render/layout.h"
+#include "netsurf/utils/log.h"
#define DEBUG_LAYOUT
@@ -395,16 +396,9 @@ struct box * layout_line(struct box * first, unsigned long width, unsigned long
} else {
/* fit as many words as possible */
assert(space != 0);
- while (xp + w < x1 - x0 && space2 != 0) {
-/* fprintf(stderr, "%li + %li = %li < %li = %li - %li\n", */
-/* xp, w, xp + w, x1 - x0, x1, x0); */
- space = space2;
- wp = w;
- space2 = strchr(space + 1, ' ');
- if (space2 == 0)
- space2 = c->text + c->length;
- w = font_width(c->font, c->text, space2 - c->text);
- }
+ space = font_split(c->font, c->text, c->length, x1 - x0 - xp, &wp);
+ LOG(("'%.*s' %lu %lu (%c) %lu", c->length, c->text,
+ x1 - x0, space - c->text, *space, wp));
c2 = memcpy(xcalloc(1, sizeof(struct box)), c, sizeof(struct box));
c2->text = xstrdup(space + 1);
c2->length = c->length - ((space + 1) - c->text);