diff options
author | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2022-01-16 17:07:41 +0100 |
---|---|---|
committer | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2022-01-16 18:37:07 +0100 |
commit | cf4bcc3f1435eafa3ed8b5fadfa9698033d1e2df (patch) | |
tree | 34b2cdc750ce7a51b7ee2a58f2d076e99d294f52 | |
parent | 1724ae7c21a6840a402a685ceea7f3366788a516 (diff) | |
download | mig-cf4bcc3f1435eafa3ed8b5fadfa9698033d1e2df.tar.gz mig-cf4bcc3f1435eafa3ed8b5fadfa9698033d1e2df.tar.bz2 mig-cf4bcc3f1435eafa3ed8b5fadfa9698033d1e2df.zip |
Also add const qualifiers on server side
Although in practice the buffers can be modified since they are from the
message, it leads to missing const where it would otherwise make sense.
-rw-r--r-- | server.c | 5 | ||||
-rw-r--r-- | utils.c | 33 | ||||
-rw-r--r-- | utils.h | 2 |
3 files changed, 36 insertions, 4 deletions
@@ -268,8 +268,9 @@ WriteLocalPtrDecl(FILE *file, const argument_t *arg) static void WriteServerArgDecl(FILE *file, const argument_t *arg) { - fprintf(file, "%s %s%s", - arg->argType->itTransType, + const char *qualif = ServerVarQualifier(arg); + fprintf(file, "%s%s %s%s", + qualif, arg->argType->itTransType, arg->argByReferenceServer ? "*" : "", arg->argVarName); } @@ -182,13 +182,42 @@ WriteUserVarDecl(FILE *file, const argument_t *arg) fprintf(file, "\t%s%s %s%s", qualif, arg->argType->itUserType, ref, arg->argVarName); } +/* Returns whether parameter should be qualified with const because we will only + receive the pointed data, not modify it. */ +static boolean_t +ServerVarConst(const argument_t *arg) +{ + return (arg->argKind & (akbSend|akbReturn)) == akbSend + && !arg->argType->itStruct; +} + +const char * +ServerVarQualifier(const argument_t *arg) +{ + if (!ServerVarConst(arg)) + return ""; + + if (arg->argType->itIndefinite || + arg->argType->itInName == MACH_MSG_TYPE_STRING_C || + !strcmp(arg->argType->itTransType, "string_t")) + /* This is a pointer, so we have to use the const_foo type to + make const qualify the data, not the pointer. + + Or this is a string_t, which should use const_string_t to avoid + forcing the caller to respect the definite string size */ + return "const_"; + else + return "const "; +} + void WriteServerVarDecl(FILE *file, const argument_t *arg) { + const char *qualif = ServerVarQualifier(arg); const char *ref = arg->argByReferenceServer ? "*" : ""; - fprintf(file, "\t%s %s%s", - arg->argType->itTransType, ref, arg->argVarName); + fprintf(file, "\t%s%s %s%s", + qualif, arg->argType->itTransType, ref, arg->argVarName); } void @@ -54,6 +54,8 @@ extern const char *ReturnTypeStr(const routine_t *rt); extern const char *FetchUserType(const ipc_type_t *it); extern const char *FetchServerType(const ipc_type_t *it); +extern const char *ServerVarQualifier(const argument_t *arg); + extern void WriteFieldDeclPrim(FILE *file, const argument_t *arg, const char *(*tfunc)(const ipc_type_t *it)); |