Mercurial > MadButterfly
diff src/shape_path.c @ 9:6eecdd331fe7
Fix bug in testcase
author | Thinker K.F. Li <thinker@branda.to> |
---|---|
date | Sat, 26 Jul 2008 04:27:52 +0800 |
parents | 94b4b5bd8810 |
children | 7cfecdce94cc |
line wrap: on
line diff
--- a/src/shape_path.c Sat Jul 26 03:20:49 2008 +0800 +++ b/src/shape_path.c Sat Jul 26 04:27:52 2008 +0800 @@ -317,6 +317,8 @@ return OK; } +/*! \brief Create a path from value of 'data' of SVG path. + */ shape_t *sh_path_new(char *data) { sh_path_t *path; int cmd_cnt, arg_cnt; @@ -362,6 +364,11 @@ return (shape_t *)path; } +/*! \brief Transform a path from user space to device space. + * + * TODO: associate coord_t with shape objects and transform them + * automatically. + */ void sh_path_transform(shape_t *shape, coord_t *coord) { sh_path_t *path; co_aix *user_args, *dev_args; @@ -514,16 +521,16 @@ path = (sh_path_t *)sh_path_new("M 33 25l33 55C 33 87 44 22 55 99L33 77z"); CU_ASSERT(path != NULL); - CU_ASSERT(path->cmd_len == 8); + CU_ASSERT(path->cmd_len == ((5 + sizeof(co_aix) * 2 + 3) & ~0x3)); CU_ASSERT(path->arg_len == 12); - CU_ASSERT(strcmp(path->user_data, "MlCLz") == 0); - CU_ASSERT(strcmp(path->dev_data, "MlCLz") == 0); + CU_ASSERT(strcmp(path->user_data, "MLCLZ") == 0); + CU_ASSERT(strcmp(path->dev_data, "MLCLZ") == 0); args = (co_aix *)(path->user_data + path->cmd_len); CU_ASSERT(args[0] == 33); CU_ASSERT(args[1] == 25); - CU_ASSERT(args[2] == 33); - CU_ASSERT(args[3] == 55); + CU_ASSERT(args[2] == 66); + CU_ASSERT(args[3] == 80); CU_ASSERT(args[4] == 33); CU_ASSERT(args[5] == 87); CU_ASSERT(args[6] == 44); @@ -542,10 +549,10 @@ path = (sh_path_t *)sh_path_new("M 33 25l33 55C 33 87 44 22 55 99L33 77z"); CU_ASSERT(path != NULL); - CU_ASSERT(path->cmd_len == 8); + CU_ASSERT(path->cmd_len == ((5 + sizeof(co_aix) * 2 + 3) & ~0x3)); CU_ASSERT(path->arg_len == 12); - CU_ASSERT(strcmp(path->user_data, "MlCLz") == 0); - CU_ASSERT(strcmp(path->dev_data, "MlCLz") == 0); + CU_ASSERT(strcmp(path->user_data, "MLCLZ") == 0); + CU_ASSERT(strcmp(path->dev_data, "MLCLZ") == 0); coord.aggr_matrix[0] = 1; coord.aggr_matrix[1] = 0; @@ -558,8 +565,8 @@ args = (co_aix *)(path->dev_data + path->cmd_len); CU_ASSERT(args[0] == 34); CU_ASSERT(args[1] == 50); - CU_ASSERT(args[2] == 34); - CU_ASSERT(args[3] == 110); + CU_ASSERT(args[2] == 67); + CU_ASSERT(args[3] == 160); CU_ASSERT(args[4] == 34); CU_ASSERT(args[5] == 174); CU_ASSERT(args[6] == 45);