aboutsummaryrefslogtreecommitdiffhomepage
path: root/uzbl.c
diff options
context:
space:
mode:
authorGravatar Barrucadu <mike@barrucadu.co.uk>2009-05-03 23:13:34 +0100
committerGravatar Barrucadu <mike@barrucadu.co.uk>2009-05-03 23:13:34 +0100
commitb6a39ed3eba72d2c3fea3ae9ed28ff7510a05e1f (patch)
treeb2b0f297ccc23cbda395f8edf92e533f97d9cb3b /uzbl.c
parentfbf3bbced3165bc67364f20d4ff6c1f994beac3b (diff)
Added hacky variable suppot (currently "%webkit-major%", "%webkit-minor%" and "%webkit-micro%", alas no "%kernver%" or "%commit%" yet) to user agent.
I'm tired and it's late. I've probably done this in a very poor way which would be infinitely better. Now I am going to go and sleep. When I wake up and come on IRC, tell me how bad the code is :P
Diffstat (limited to 'uzbl.c')
-rw-r--r--uzbl.c16
1 files changed, 12 insertions, 4 deletions
diff --git a/uzbl.c b/uzbl.c
index af414ed..8e25903 100644
--- a/uzbl.c
+++ b/uzbl.c
@@ -134,20 +134,20 @@ itos(int val) {
static char *
str_replace (const char* search, const char* replace, const char* string) {
- char newstring[512];
- char tempstring[512];
+ char newstring[1024];
+ char tempstring[1024];
unsigned int i = 0;
memset (newstring, 0, sizeof (newstring));
for (i = 0; i < strlen (string) - strlen (search); i ++) {
memset (tempstring, 0, sizeof (tempstring));
- strncpy (tempstring, string + i, sizeof (search) + 1);
+ strncpy (tempstring, string + i, strlen (search));
if (strcmp (tempstring, search) == 0) {
strncpy (newstring, string, i);
strcat (newstring, replace);
- strcat (newstring, string + i + sizeof (search) + 1);
+ strcat (newstring, string + i + strlen (search));
}
}
@@ -981,6 +981,14 @@ settings_init () {
}
if(useragent){
+ char* newagent = malloc(1024);
+
+ strcpy(newagent, str_replace("%webkit-major%", itos(WEBKIT_MAJOR_VERSION), useragent));
+ strcpy(newagent, str_replace("%webkit-minor%", itos(WEBKIT_MINOR_VERSION), newagent));
+ strcpy(newagent, str_replace("%webkit-micro%", itos(WEBKIT_MICRO_VERSION), newagent));
+
+ useragent = malloc(1024);
+ strcpy(useragent, newagent);
g_object_set(G_OBJECT(soup_session), SOUP_SESSION_USER_AGENT, useragent, NULL);
}