diff options
author | marha <marha@users.sourceforge.net> | 2011-01-22 17:28:46 +0000 |
---|---|---|
committer | marha <marha@users.sourceforge.net> | 2011-01-22 17:28:46 +0000 |
commit | f544012f5c37fba02cae71b39a533f8296cdabb5 (patch) | |
tree | 362b7ac783787d77962014f5f8e4e7c116de3f3f /mesalib/src/glsl/glcpp/glcpp-parse.y | |
parent | 58eb5cd6de079f1f3ddf1edc2d436a24eb858dc2 (diff) | |
parent | b8ffa56f8bda74a402eae0c89aadfda7b7db507f (diff) | |
download | vcxsrv-f544012f5c37fba02cae71b39a533f8296cdabb5.tar.gz vcxsrv-f544012f5c37fba02cae71b39a533f8296cdabb5.tar.bz2 vcxsrv-f544012f5c37fba02cae71b39a533f8296cdabb5.zip |
svn merge ^/branches/released .
Diffstat (limited to 'mesalib/src/glsl/glcpp/glcpp-parse.y')
-rw-r--r-- | mesalib/src/glsl/glcpp/glcpp-parse.y | 20 |
1 files changed, 7 insertions, 13 deletions
diff --git a/mesalib/src/glsl/glcpp/glcpp-parse.y b/mesalib/src/glsl/glcpp/glcpp-parse.y index 5ece8b3bb..a64d6691c 100644 --- a/mesalib/src/glsl/glcpp/glcpp-parse.y +++ b/mesalib/src/glsl/glcpp/glcpp-parse.y @@ -89,10 +89,7 @@ _token_create_ival (void *ctx, int type, int ival); static token_list_t *
_token_list_create (void *ctx);
-/* Note: This function adds a talloc_reference() to token.
- *
- * You may want to talloc_unlink any current reference if you no
- * longer need it. */
+/* Note: This function calls talloc_steal on token. */
static void
_token_list_append (token_list_t *list, token_t *token);
@@ -479,12 +476,10 @@ conditional_tokens: conditional_token {
$$ = _token_list_create (parser);
_token_list_append ($$, $1);
- talloc_unlink (parser, $1);
}
| conditional_tokens conditional_token {
$$ = $1;
_token_list_append ($$, $2);
- talloc_unlink (parser, $2);
}
;
@@ -493,12 +488,10 @@ pp_tokens: parser->space_tokens = 1;
$$ = _token_list_create (parser);
_token_list_append ($$, $1);
- talloc_unlink (parser, $1);
}
| pp_tokens preprocessing_token {
$$ = $1;
_token_list_append ($$, $2);
- talloc_unlink (parser, $2);
}
;
@@ -764,7 +757,7 @@ _token_list_append (token_list_t *list, token_t *token) token_node_t *node;
node = talloc (list, token_node_t);
- node->token = talloc_reference (list, token);
+ node->token = talloc_steal (list, token);
node->next = NULL;
@@ -805,8 +798,11 @@ _token_list_copy (void *ctx, token_list_t *other) return NULL;
copy = _token_list_create (ctx);
- for (node = other->head; node; node = node->next)
- _token_list_append (copy, node->token);
+ for (node = other->head; node; node = node->next) {
+ token_t *new_token = talloc (copy, token_t);
+ *new_token = *node->token;
+ _token_list_append (copy, new_token);
+ }
return copy;
}
@@ -1081,8 +1077,6 @@ static void add_builtin_define(glcpp_parser_t *parser, list = _token_list_create(parser);
_token_list_append(list, tok);
_define_object_macro(parser, NULL, name, list);
-
- talloc_unlink(parser, tok);
}
glcpp_parser_t *
|