Refactored settings clone/free, extended tests

This commit is contained in:
akallabeth 2020-05-15 12:22:37 +02:00
parent a887c890f2
commit 319afb082b
6 changed files with 621 additions and 247 deletions

View File

@ -2358,7 +2358,7 @@ const char* freerdp_settings_get_string(const rdpSettings* settings, size_t id)
} }
} }
BOOL freerdp_settings_set_string(rdpSettings* settings, size_t id, const char* val) BOOL freerdp_settings_set_string_(rdpSettings* settings, size_t id, const char* val, BOOL cleanup)
{ {
if (!settings) if (!settings)
return FALSE; return FALSE;
@ -2366,331 +2366,397 @@ BOOL freerdp_settings_set_string(rdpSettings* settings, size_t id, const char* v
switch (id) switch (id)
{ {
case FreeRDP_AcceptedCert: case FreeRDP_AcceptedCert:
if (cleanup)
free(settings->AcceptedCert); free(settings->AcceptedCert);
settings->AcceptedCert = (val ? _strdup(val) : NULL); settings->AcceptedCert = (val ? _strdup(val) : NULL);
return (!val || settings->AcceptedCert != NULL); return (!val || settings->AcceptedCert != NULL);
case FreeRDP_AllowedTlsCiphers: case FreeRDP_AllowedTlsCiphers:
if (cleanup)
free(settings->AllowedTlsCiphers); free(settings->AllowedTlsCiphers);
settings->AllowedTlsCiphers = (val ? _strdup(val) : NULL); settings->AllowedTlsCiphers = (val ? _strdup(val) : NULL);
return (!val || settings->AllowedTlsCiphers != NULL); return (!val || settings->AllowedTlsCiphers != NULL);
case FreeRDP_AlternateShell: case FreeRDP_AlternateShell:
if (cleanup)
free(settings->AlternateShell); free(settings->AlternateShell);
settings->AlternateShell = (val ? _strdup(val) : NULL); settings->AlternateShell = (val ? _strdup(val) : NULL);
return (!val || settings->AlternateShell != NULL); return (!val || settings->AlternateShell != NULL);
case FreeRDP_AssistanceFile: case FreeRDP_AssistanceFile:
if (cleanup)
free(settings->AssistanceFile); free(settings->AssistanceFile);
settings->AssistanceFile = (val ? _strdup(val) : NULL); settings->AssistanceFile = (val ? _strdup(val) : NULL);
return (!val || settings->AssistanceFile != NULL); return (!val || settings->AssistanceFile != NULL);
case FreeRDP_AuthenticationServiceClass: case FreeRDP_AuthenticationServiceClass:
if (cleanup)
free(settings->AuthenticationServiceClass); free(settings->AuthenticationServiceClass);
settings->AuthenticationServiceClass = (val ? _strdup(val) : NULL); settings->AuthenticationServiceClass = (val ? _strdup(val) : NULL);
return (!val || settings->AuthenticationServiceClass != NULL); return (!val || settings->AuthenticationServiceClass != NULL);
case FreeRDP_CertificateAcceptedFingerprints: case FreeRDP_CertificateAcceptedFingerprints:
if (cleanup)
free(settings->CertificateAcceptedFingerprints); free(settings->CertificateAcceptedFingerprints);
settings->CertificateAcceptedFingerprints = (val ? _strdup(val) : NULL); settings->CertificateAcceptedFingerprints = (val ? _strdup(val) : NULL);
return (!val || settings->CertificateAcceptedFingerprints != NULL); return (!val || settings->CertificateAcceptedFingerprints != NULL);
case FreeRDP_CertificateContent: case FreeRDP_CertificateContent:
if (cleanup)
free(settings->CertificateContent); free(settings->CertificateContent);
settings->CertificateContent = (val ? _strdup(val) : NULL); settings->CertificateContent = (val ? _strdup(val) : NULL);
return (!val || settings->CertificateContent != NULL); return (!val || settings->CertificateContent != NULL);
case FreeRDP_CertificateFile: case FreeRDP_CertificateFile:
if (cleanup)
free(settings->CertificateFile); free(settings->CertificateFile);
settings->CertificateFile = (val ? _strdup(val) : NULL); settings->CertificateFile = (val ? _strdup(val) : NULL);
return (!val || settings->CertificateFile != NULL); return (!val || settings->CertificateFile != NULL);
case FreeRDP_CertificateName: case FreeRDP_CertificateName:
if (cleanup)
free(settings->CertificateName); free(settings->CertificateName);
settings->CertificateName = (val ? _strdup(val) : NULL); settings->CertificateName = (val ? _strdup(val) : NULL);
return (!val || settings->CertificateName != NULL); return (!val || settings->CertificateName != NULL);
case FreeRDP_ClientAddress: case FreeRDP_ClientAddress:
if (cleanup)
free(settings->ClientAddress); free(settings->ClientAddress);
settings->ClientAddress = (val ? _strdup(val) : NULL); settings->ClientAddress = (val ? _strdup(val) : NULL);
return (!val || settings->ClientAddress != NULL); return (!val || settings->ClientAddress != NULL);
case FreeRDP_ClientDir: case FreeRDP_ClientDir:
if (cleanup)
free(settings->ClientDir); free(settings->ClientDir);
settings->ClientDir = (val ? _strdup(val) : NULL); settings->ClientDir = (val ? _strdup(val) : NULL);
return (!val || settings->ClientDir != NULL); return (!val || settings->ClientDir != NULL);
case FreeRDP_ClientHostname: case FreeRDP_ClientHostname:
if (cleanup)
free(settings->ClientHostname); free(settings->ClientHostname);
settings->ClientHostname = (val ? _strdup(val) : NULL); settings->ClientHostname = (val ? _strdup(val) : NULL);
return (!val || settings->ClientHostname != NULL); return (!val || settings->ClientHostname != NULL);
case FreeRDP_ClientProductId: case FreeRDP_ClientProductId:
if (cleanup)
free(settings->ClientProductId); free(settings->ClientProductId);
settings->ClientProductId = (val ? _strdup(val) : NULL); settings->ClientProductId = (val ? _strdup(val) : NULL);
return (!val || settings->ClientProductId != NULL); return (!val || settings->ClientProductId != NULL);
case FreeRDP_ComputerName: case FreeRDP_ComputerName:
if (cleanup)
free(settings->ComputerName); free(settings->ComputerName);
settings->ComputerName = (val ? _strdup(val) : NULL); settings->ComputerName = (val ? _strdup(val) : NULL);
return (!val || settings->ComputerName != NULL); return (!val || settings->ComputerName != NULL);
case FreeRDP_ConfigPath: case FreeRDP_ConfigPath:
if (cleanup)
free(settings->ConfigPath); free(settings->ConfigPath);
settings->ConfigPath = (val ? _strdup(val) : NULL); settings->ConfigPath = (val ? _strdup(val) : NULL);
return (!val || settings->ConfigPath != NULL); return (!val || settings->ConfigPath != NULL);
case FreeRDP_ConnectionFile: case FreeRDP_ConnectionFile:
if (cleanup)
free(settings->ConnectionFile); free(settings->ConnectionFile);
settings->ConnectionFile = (val ? _strdup(val) : NULL); settings->ConnectionFile = (val ? _strdup(val) : NULL);
return (!val || settings->ConnectionFile != NULL); return (!val || settings->ConnectionFile != NULL);
case FreeRDP_CurrentPath: case FreeRDP_CurrentPath:
if (cleanup)
free(settings->CurrentPath); free(settings->CurrentPath);
settings->CurrentPath = (val ? _strdup(val) : NULL); settings->CurrentPath = (val ? _strdup(val) : NULL);
return (!val || settings->CurrentPath != NULL); return (!val || settings->CurrentPath != NULL);
case FreeRDP_Domain: case FreeRDP_Domain:
if (cleanup)
free(settings->Domain); free(settings->Domain);
settings->Domain = (val ? _strdup(val) : NULL); settings->Domain = (val ? _strdup(val) : NULL);
return (!val || settings->Domain != NULL); return (!val || settings->Domain != NULL);
case FreeRDP_DrivesToRedirect: case FreeRDP_DrivesToRedirect:
if (cleanup)
free(settings->DrivesToRedirect); free(settings->DrivesToRedirect);
settings->DrivesToRedirect = (val ? _strdup(val) : NULL); settings->DrivesToRedirect = (val ? _strdup(val) : NULL);
return (!val || settings->DrivesToRedirect != NULL); return (!val || settings->DrivesToRedirect != NULL);
case FreeRDP_DumpRemoteFxFile: case FreeRDP_DumpRemoteFxFile:
if (cleanup)
free(settings->DumpRemoteFxFile); free(settings->DumpRemoteFxFile);
settings->DumpRemoteFxFile = (val ? _strdup(val) : NULL); settings->DumpRemoteFxFile = (val ? _strdup(val) : NULL);
return (!val || settings->DumpRemoteFxFile != NULL); return (!val || settings->DumpRemoteFxFile != NULL);
case FreeRDP_DynamicDSTTimeZoneKeyName: case FreeRDP_DynamicDSTTimeZoneKeyName:
if (cleanup)
free(settings->DynamicDSTTimeZoneKeyName); free(settings->DynamicDSTTimeZoneKeyName);
settings->DynamicDSTTimeZoneKeyName = (val ? _strdup(val) : NULL); settings->DynamicDSTTimeZoneKeyName = (val ? _strdup(val) : NULL);
return (!val || settings->DynamicDSTTimeZoneKeyName != NULL); return (!val || settings->DynamicDSTTimeZoneKeyName != NULL);
case FreeRDP_GatewayAcceptedCert: case FreeRDP_GatewayAcceptedCert:
if (cleanup)
free(settings->GatewayAcceptedCert); free(settings->GatewayAcceptedCert);
settings->GatewayAcceptedCert = (val ? _strdup(val) : NULL); settings->GatewayAcceptedCert = (val ? _strdup(val) : NULL);
return (!val || settings->GatewayAcceptedCert != NULL); return (!val || settings->GatewayAcceptedCert != NULL);
case FreeRDP_GatewayAccessToken: case FreeRDP_GatewayAccessToken:
if (cleanup)
free(settings->GatewayAccessToken); free(settings->GatewayAccessToken);
settings->GatewayAccessToken = (val ? _strdup(val) : NULL); settings->GatewayAccessToken = (val ? _strdup(val) : NULL);
return (!val || settings->GatewayAccessToken != NULL); return (!val || settings->GatewayAccessToken != NULL);
case FreeRDP_GatewayDomain: case FreeRDP_GatewayDomain:
if (cleanup)
free(settings->GatewayDomain); free(settings->GatewayDomain);
settings->GatewayDomain = (val ? _strdup(val) : NULL); settings->GatewayDomain = (val ? _strdup(val) : NULL);
return (!val || settings->GatewayDomain != NULL); return (!val || settings->GatewayDomain != NULL);
case FreeRDP_GatewayHostname: case FreeRDP_GatewayHostname:
if (cleanup)
free(settings->GatewayHostname); free(settings->GatewayHostname);
settings->GatewayHostname = (val ? _strdup(val) : NULL); settings->GatewayHostname = (val ? _strdup(val) : NULL);
return (!val || settings->GatewayHostname != NULL); return (!val || settings->GatewayHostname != NULL);
case FreeRDP_GatewayPassword: case FreeRDP_GatewayPassword:
if (cleanup)
free(settings->GatewayPassword); free(settings->GatewayPassword);
settings->GatewayPassword = (val ? _strdup(val) : NULL); settings->GatewayPassword = (val ? _strdup(val) : NULL);
return (!val || settings->GatewayPassword != NULL); return (!val || settings->GatewayPassword != NULL);
case FreeRDP_GatewayUsername: case FreeRDP_GatewayUsername:
if (cleanup)
free(settings->GatewayUsername); free(settings->GatewayUsername);
settings->GatewayUsername = (val ? _strdup(val) : NULL); settings->GatewayUsername = (val ? _strdup(val) : NULL);
return (!val || settings->GatewayUsername != NULL); return (!val || settings->GatewayUsername != NULL);
case FreeRDP_HomePath: case FreeRDP_HomePath:
if (cleanup)
free(settings->HomePath); free(settings->HomePath);
settings->HomePath = (val ? _strdup(val) : NULL); settings->HomePath = (val ? _strdup(val) : NULL);
return (!val || settings->HomePath != NULL); return (!val || settings->HomePath != NULL);
case FreeRDP_ImeFileName: case FreeRDP_ImeFileName:
if (cleanup)
free(settings->ImeFileName); free(settings->ImeFileName);
settings->ImeFileName = (val ? _strdup(val) : NULL); settings->ImeFileName = (val ? _strdup(val) : NULL);
return (!val || settings->ImeFileName != NULL); return (!val || settings->ImeFileName != NULL);
case FreeRDP_KerberosKdc: case FreeRDP_KerberosKdc:
if (cleanup)
free(settings->KerberosKdc); free(settings->KerberosKdc);
settings->KerberosKdc = (val ? _strdup(val) : NULL); settings->KerberosKdc = (val ? _strdup(val) : NULL);
return (!val || settings->KerberosKdc != NULL); return (!val || settings->KerberosKdc != NULL);
case FreeRDP_KerberosRealm: case FreeRDP_KerberosRealm:
if (cleanup)
free(settings->KerberosRealm); free(settings->KerberosRealm);
settings->KerberosRealm = (val ? _strdup(val) : NULL); settings->KerberosRealm = (val ? _strdup(val) : NULL);
return (!val || settings->KerberosRealm != NULL); return (!val || settings->KerberosRealm != NULL);
case FreeRDP_NtlmSamFile: case FreeRDP_NtlmSamFile:
if (cleanup)
free(settings->NtlmSamFile); free(settings->NtlmSamFile);
settings->NtlmSamFile = (val ? _strdup(val) : NULL); settings->NtlmSamFile = (val ? _strdup(val) : NULL);
return (!val || settings->NtlmSamFile != NULL); return (!val || settings->NtlmSamFile != NULL);
case FreeRDP_Password: case FreeRDP_Password:
if (cleanup)
free(settings->Password); free(settings->Password);
settings->Password = (val ? _strdup(val) : NULL); settings->Password = (val ? _strdup(val) : NULL);
return (!val || settings->Password != NULL); return (!val || settings->Password != NULL);
case FreeRDP_PasswordHash: case FreeRDP_PasswordHash:
if (cleanup)
free(settings->PasswordHash); free(settings->PasswordHash);
settings->PasswordHash = (val ? _strdup(val) : NULL); settings->PasswordHash = (val ? _strdup(val) : NULL);
return (!val || settings->PasswordHash != NULL); return (!val || settings->PasswordHash != NULL);
case FreeRDP_PlayRemoteFxFile: case FreeRDP_PlayRemoteFxFile:
if (cleanup)
free(settings->PlayRemoteFxFile); free(settings->PlayRemoteFxFile);
settings->PlayRemoteFxFile = (val ? _strdup(val) : NULL); settings->PlayRemoteFxFile = (val ? _strdup(val) : NULL);
return (!val || settings->PlayRemoteFxFile != NULL); return (!val || settings->PlayRemoteFxFile != NULL);
case FreeRDP_PreconnectionBlob: case FreeRDP_PreconnectionBlob:
if (cleanup)
free(settings->PreconnectionBlob); free(settings->PreconnectionBlob);
settings->PreconnectionBlob = (val ? _strdup(val) : NULL); settings->PreconnectionBlob = (val ? _strdup(val) : NULL);
return (!val || settings->PreconnectionBlob != NULL); return (!val || settings->PreconnectionBlob != NULL);
case FreeRDP_PrivateKeyContent: case FreeRDP_PrivateKeyContent:
if (cleanup)
free(settings->PrivateKeyContent); free(settings->PrivateKeyContent);
settings->PrivateKeyContent = (val ? _strdup(val) : NULL); settings->PrivateKeyContent = (val ? _strdup(val) : NULL);
return (!val || settings->PrivateKeyContent != NULL); return (!val || settings->PrivateKeyContent != NULL);
case FreeRDP_PrivateKeyFile: case FreeRDP_PrivateKeyFile:
if (cleanup)
free(settings->PrivateKeyFile); free(settings->PrivateKeyFile);
settings->PrivateKeyFile = (val ? _strdup(val) : NULL); settings->PrivateKeyFile = (val ? _strdup(val) : NULL);
return (!val || settings->PrivateKeyFile != NULL); return (!val || settings->PrivateKeyFile != NULL);
case FreeRDP_ProxyHostname: case FreeRDP_ProxyHostname:
if (cleanup)
free(settings->ProxyHostname); free(settings->ProxyHostname);
settings->ProxyHostname = (val ? _strdup(val) : NULL); settings->ProxyHostname = (val ? _strdup(val) : NULL);
return (!val || settings->ProxyHostname != NULL); return (!val || settings->ProxyHostname != NULL);
case FreeRDP_ProxyPassword: case FreeRDP_ProxyPassword:
if (cleanup)
free(settings->ProxyPassword); free(settings->ProxyPassword);
settings->ProxyPassword = (val ? _strdup(val) : NULL); settings->ProxyPassword = (val ? _strdup(val) : NULL);
return (!val || settings->ProxyPassword != NULL); return (!val || settings->ProxyPassword != NULL);
case FreeRDP_ProxyUsername: case FreeRDP_ProxyUsername:
if (cleanup)
free(settings->ProxyUsername); free(settings->ProxyUsername);
settings->ProxyUsername = (val ? _strdup(val) : NULL); settings->ProxyUsername = (val ? _strdup(val) : NULL);
return (!val || settings->ProxyUsername != NULL); return (!val || settings->ProxyUsername != NULL);
case FreeRDP_RDP2TCPArgs: case FreeRDP_RDP2TCPArgs:
if (cleanup)
free(settings->RDP2TCPArgs); free(settings->RDP2TCPArgs);
settings->RDP2TCPArgs = (val ? _strdup(val) : NULL); settings->RDP2TCPArgs = (val ? _strdup(val) : NULL);
return (!val || settings->RDP2TCPArgs != NULL); return (!val || settings->RDP2TCPArgs != NULL);
case FreeRDP_RdpKeyContent: case FreeRDP_RdpKeyContent:
if (cleanup)
free(settings->RdpKeyContent); free(settings->RdpKeyContent);
settings->RdpKeyContent = (val ? _strdup(val) : NULL); settings->RdpKeyContent = (val ? _strdup(val) : NULL);
return (!val || settings->RdpKeyContent != NULL); return (!val || settings->RdpKeyContent != NULL);
case FreeRDP_RdpKeyFile: case FreeRDP_RdpKeyFile:
if (cleanup)
free(settings->RdpKeyFile); free(settings->RdpKeyFile);
settings->RdpKeyFile = (val ? _strdup(val) : NULL); settings->RdpKeyFile = (val ? _strdup(val) : NULL);
return (!val || settings->RdpKeyFile != NULL); return (!val || settings->RdpKeyFile != NULL);
case FreeRDP_RedirectionAcceptedCert: case FreeRDP_RedirectionAcceptedCert:
if (cleanup)
free(settings->RedirectionAcceptedCert); free(settings->RedirectionAcceptedCert);
settings->RedirectionAcceptedCert = (val ? _strdup(val) : NULL); settings->RedirectionAcceptedCert = (val ? _strdup(val) : NULL);
return (!val || settings->RedirectionAcceptedCert != NULL); return (!val || settings->RedirectionAcceptedCert != NULL);
case FreeRDP_RedirectionDomain: case FreeRDP_RedirectionDomain:
if (cleanup)
free(settings->RedirectionDomain); free(settings->RedirectionDomain);
settings->RedirectionDomain = (val ? _strdup(val) : NULL); settings->RedirectionDomain = (val ? _strdup(val) : NULL);
return (!val || settings->RedirectionDomain != NULL); return (!val || settings->RedirectionDomain != NULL);
case FreeRDP_RedirectionTargetFQDN: case FreeRDP_RedirectionTargetFQDN:
if (cleanup)
free(settings->RedirectionTargetFQDN); free(settings->RedirectionTargetFQDN);
settings->RedirectionTargetFQDN = (val ? _strdup(val) : NULL); settings->RedirectionTargetFQDN = (val ? _strdup(val) : NULL);
return (!val || settings->RedirectionTargetFQDN != NULL); return (!val || settings->RedirectionTargetFQDN != NULL);
case FreeRDP_RedirectionTargetNetBiosName: case FreeRDP_RedirectionTargetNetBiosName:
if (cleanup)
free(settings->RedirectionTargetNetBiosName); free(settings->RedirectionTargetNetBiosName);
settings->RedirectionTargetNetBiosName = (val ? _strdup(val) : NULL); settings->RedirectionTargetNetBiosName = (val ? _strdup(val) : NULL);
return (!val || settings->RedirectionTargetNetBiosName != NULL); return (!val || settings->RedirectionTargetNetBiosName != NULL);
case FreeRDP_RedirectionUsername: case FreeRDP_RedirectionUsername:
if (cleanup)
free(settings->RedirectionUsername); free(settings->RedirectionUsername);
settings->RedirectionUsername = (val ? _strdup(val) : NULL); settings->RedirectionUsername = (val ? _strdup(val) : NULL);
return (!val || settings->RedirectionUsername != NULL); return (!val || settings->RedirectionUsername != NULL);
case FreeRDP_RemoteApplicationCmdLine: case FreeRDP_RemoteApplicationCmdLine:
if (cleanup)
free(settings->RemoteApplicationCmdLine); free(settings->RemoteApplicationCmdLine);
settings->RemoteApplicationCmdLine = (val ? _strdup(val) : NULL); settings->RemoteApplicationCmdLine = (val ? _strdup(val) : NULL);
return (!val || settings->RemoteApplicationCmdLine != NULL); return (!val || settings->RemoteApplicationCmdLine != NULL);
case FreeRDP_RemoteApplicationFile: case FreeRDP_RemoteApplicationFile:
if (cleanup)
free(settings->RemoteApplicationFile); free(settings->RemoteApplicationFile);
settings->RemoteApplicationFile = (val ? _strdup(val) : NULL); settings->RemoteApplicationFile = (val ? _strdup(val) : NULL);
return (!val || settings->RemoteApplicationFile != NULL); return (!val || settings->RemoteApplicationFile != NULL);
case FreeRDP_RemoteApplicationGuid: case FreeRDP_RemoteApplicationGuid:
if (cleanup)
free(settings->RemoteApplicationGuid); free(settings->RemoteApplicationGuid);
settings->RemoteApplicationGuid = (val ? _strdup(val) : NULL); settings->RemoteApplicationGuid = (val ? _strdup(val) : NULL);
return (!val || settings->RemoteApplicationGuid != NULL); return (!val || settings->RemoteApplicationGuid != NULL);
case FreeRDP_RemoteApplicationIcon: case FreeRDP_RemoteApplicationIcon:
if (cleanup)
free(settings->RemoteApplicationIcon); free(settings->RemoteApplicationIcon);
settings->RemoteApplicationIcon = (val ? _strdup(val) : NULL); settings->RemoteApplicationIcon = (val ? _strdup(val) : NULL);
return (!val || settings->RemoteApplicationIcon != NULL); return (!val || settings->RemoteApplicationIcon != NULL);
case FreeRDP_RemoteApplicationName: case FreeRDP_RemoteApplicationName:
if (cleanup)
free(settings->RemoteApplicationName); free(settings->RemoteApplicationName);
settings->RemoteApplicationName = (val ? _strdup(val) : NULL); settings->RemoteApplicationName = (val ? _strdup(val) : NULL);
return (!val || settings->RemoteApplicationName != NULL); return (!val || settings->RemoteApplicationName != NULL);
case FreeRDP_RemoteApplicationProgram: case FreeRDP_RemoteApplicationProgram:
if (cleanup)
free(settings->RemoteApplicationProgram); free(settings->RemoteApplicationProgram);
settings->RemoteApplicationProgram = (val ? _strdup(val) : NULL); settings->RemoteApplicationProgram = (val ? _strdup(val) : NULL);
return (!val || settings->RemoteApplicationProgram != NULL); return (!val || settings->RemoteApplicationProgram != NULL);
case FreeRDP_RemoteApplicationWorkingDir: case FreeRDP_RemoteApplicationWorkingDir:
if (cleanup)
free(settings->RemoteApplicationWorkingDir); free(settings->RemoteApplicationWorkingDir);
settings->RemoteApplicationWorkingDir = (val ? _strdup(val) : NULL); settings->RemoteApplicationWorkingDir = (val ? _strdup(val) : NULL);
return (!val || settings->RemoteApplicationWorkingDir != NULL); return (!val || settings->RemoteApplicationWorkingDir != NULL);
case FreeRDP_RemoteAssistancePassStub: case FreeRDP_RemoteAssistancePassStub:
if (cleanup)
free(settings->RemoteAssistancePassStub); free(settings->RemoteAssistancePassStub);
settings->RemoteAssistancePassStub = (val ? _strdup(val) : NULL); settings->RemoteAssistancePassStub = (val ? _strdup(val) : NULL);
return (!val || settings->RemoteAssistancePassStub != NULL); return (!val || settings->RemoteAssistancePassStub != NULL);
case FreeRDP_RemoteAssistancePassword: case FreeRDP_RemoteAssistancePassword:
if (cleanup)
free(settings->RemoteAssistancePassword); free(settings->RemoteAssistancePassword);
settings->RemoteAssistancePassword = (val ? _strdup(val) : NULL); settings->RemoteAssistancePassword = (val ? _strdup(val) : NULL);
return (!val || settings->RemoteAssistancePassword != NULL); return (!val || settings->RemoteAssistancePassword != NULL);
case FreeRDP_RemoteAssistanceRCTicket: case FreeRDP_RemoteAssistanceRCTicket:
if (cleanup)
free(settings->RemoteAssistanceRCTicket); free(settings->RemoteAssistanceRCTicket);
settings->RemoteAssistanceRCTicket = (val ? _strdup(val) : NULL); settings->RemoteAssistanceRCTicket = (val ? _strdup(val) : NULL);
return (!val || settings->RemoteAssistanceRCTicket != NULL); return (!val || settings->RemoteAssistanceRCTicket != NULL);
case FreeRDP_RemoteAssistanceSessionId: case FreeRDP_RemoteAssistanceSessionId:
if (cleanup)
free(settings->RemoteAssistanceSessionId); free(settings->RemoteAssistanceSessionId);
settings->RemoteAssistanceSessionId = (val ? _strdup(val) : NULL); settings->RemoteAssistanceSessionId = (val ? _strdup(val) : NULL);
return (!val || settings->RemoteAssistanceSessionId != NULL); return (!val || settings->RemoteAssistanceSessionId != NULL);
case FreeRDP_ServerHostname: case FreeRDP_ServerHostname:
if (cleanup)
free(settings->ServerHostname); free(settings->ServerHostname);
settings->ServerHostname = (val ? _strdup(val) : NULL); settings->ServerHostname = (val ? _strdup(val) : NULL);
return (!val || settings->ServerHostname != NULL); return (!val || settings->ServerHostname != NULL);
case FreeRDP_ShellWorkingDirectory: case FreeRDP_ShellWorkingDirectory:
if (cleanup)
free(settings->ShellWorkingDirectory); free(settings->ShellWorkingDirectory);
settings->ShellWorkingDirectory = (val ? _strdup(val) : NULL); settings->ShellWorkingDirectory = (val ? _strdup(val) : NULL);
return (!val || settings->ShellWorkingDirectory != NULL); return (!val || settings->ShellWorkingDirectory != NULL);
case FreeRDP_TargetNetAddress: case FreeRDP_TargetNetAddress:
if (cleanup)
free(settings->TargetNetAddress); free(settings->TargetNetAddress);
settings->TargetNetAddress = (val ? _strdup(val) : NULL); settings->TargetNetAddress = (val ? _strdup(val) : NULL);
return (!val || settings->TargetNetAddress != NULL); return (!val || settings->TargetNetAddress != NULL);
case FreeRDP_Username: case FreeRDP_Username:
if (cleanup)
free(settings->Username); free(settings->Username);
settings->Username = (val ? _strdup(val) : NULL); settings->Username = (val ? _strdup(val) : NULL);
return (!val || settings->Username != NULL); return (!val || settings->Username != NULL);
case FreeRDP_WindowTitle: case FreeRDP_WindowTitle:
if (cleanup)
free(settings->WindowTitle); free(settings->WindowTitle);
settings->WindowTitle = (val ? _strdup(val) : NULL); settings->WindowTitle = (val ? _strdup(val) : NULL);
return (!val || settings->WindowTitle != NULL); return (!val || settings->WindowTitle != NULL);
case FreeRDP_WmClass: case FreeRDP_WmClass:
if (cleanup)
free(settings->WmClass); free(settings->WmClass);
settings->WmClass = (val ? _strdup(val) : NULL); settings->WmClass = (val ? _strdup(val) : NULL);
return (!val || settings->WmClass != NULL); return (!val || settings->WmClass != NULL);
@ -2702,6 +2768,11 @@ BOOL freerdp_settings_set_string(rdpSettings* settings, size_t id, const char* v
return TRUE; return TRUE;
} }
BOOL freerdp_settings_set_string(rdpSettings* settings, size_t id, const char* val)
{
return freerdp_settings_set_string_(settings, id, val, TRUE);
}
const void* freerdp_settings_get_pointer(const rdpSettings* settings, size_t id) const void* freerdp_settings_get_pointer(const rdpSettings* settings, size_t id)
{ {
if (!settings) if (!settings)
@ -2792,3 +2863,121 @@ const void* freerdp_settings_get_pointer(const rdpSettings* settings, size_t id)
return FALSE; return FALSE;
} }
} }
BOOL freerdp_settings_set_pointer(rdpSettings* settings, size_t id, const void* val)
{
if (!settings)
return FALSE;
switch (id)
{
case FreeRDP_BitmapCacheV2CellInfo:
settings->BitmapCacheV2CellInfo = (void*)val;
break;
case FreeRDP_ChannelDefArray:
settings->ChannelDefArray = (void*)val;
break;
case FreeRDP_ClientAutoReconnectCookie:
settings->ClientAutoReconnectCookie = (void*)val;
break;
case FreeRDP_ClientRandom:
settings->ClientRandom = (void*)val;
break;
case FreeRDP_ClientTimeZone:
settings->ClientTimeZone = (void*)val;
break;
case FreeRDP_DeviceArray:
settings->DeviceArray = (void*)val;
break;
case FreeRDP_DynamicChannelArray:
settings->DynamicChannelArray = (void*)val;
break;
case FreeRDP_FragCache:
settings->FragCache = (void*)val;
break;
case FreeRDP_GlyphCache:
settings->GlyphCache = (void*)val;
break;
case FreeRDP_LoadBalanceInfo:
settings->LoadBalanceInfo = (void*)val;
break;
case FreeRDP_MonitorDefArray:
settings->MonitorDefArray = (void*)val;
break;
case FreeRDP_MonitorIds:
settings->MonitorIds = (void*)val;
break;
case FreeRDP_OrderSupport:
settings->OrderSupport = (void*)val;
break;
case FreeRDP_Password51:
settings->Password51 = (void*)val;
break;
case FreeRDP_RdpServerCertificate:
settings->RdpServerCertificate = (void*)val;
break;
case FreeRDP_RdpServerRsaKey:
settings->RdpServerRsaKey = (void*)val;
break;
case FreeRDP_ReceivedCapabilities:
settings->ReceivedCapabilities = (void*)val;
break;
case FreeRDP_RedirectionPassword:
settings->RedirectionPassword = (void*)val;
break;
case FreeRDP_RedirectionTsvUrl:
settings->RedirectionTsvUrl = (void*)val;
break;
case FreeRDP_ServerAutoReconnectCookie:
settings->ServerAutoReconnectCookie = (void*)val;
break;
case FreeRDP_ServerCertificate:
settings->ServerCertificate = (void*)val;
break;
case FreeRDP_ServerRandom:
settings->ServerRandom = (void*)val;
break;
case FreeRDP_StaticChannelArray:
settings->StaticChannelArray = (void*)val;
break;
case FreeRDP_TargetNetAddresses:
settings->TargetNetAddresses = (void*)val;
break;
case FreeRDP_TargetNetPorts:
settings->TargetNetPorts = (void*)val;
break;
case FreeRDP_instance:
settings->instance = (void*)val;
break;
default:
WLog_ERR(TAG, "[%s] Invalid key index %" PRIuz, __FUNCTION__, id);
return FALSE;
}
return TRUE;
}

View File

@ -3,6 +3,8 @@
#include <freerdp/settings.h> #include <freerdp/settings.h>
#include <freerdp/log.h> #include <freerdp/log.h>
#include "../core/settings.h"
#define TAG FREERDP_TAG("common.settings") #define TAG FREERDP_TAG("common.settings")
struct settings_str_entry struct settings_str_entry
@ -385,6 +387,100 @@ static const struct settings_str_entry settings_map[] = {
{ FreeRDP_instance, 8, "FreeRDP_instance" }, { FreeRDP_instance, 8, "FreeRDP_instance" },
}; };
BOOL freerdp_settings_clone_keys(rdpSettings* dst, const rdpSettings* src)
{
size_t x;
for (x = 0; x < ARRAYSIZE(settings_map); x++)
{
const struct settings_str_entry* cur = &settings_map[x];
switch (cur->type)
{
case 0: /* bool */
{
BOOL sval = freerdp_settings_get_bool(src, cur->id);
if (!freerdp_settings_set_bool(dst, cur->id, sval))
return FALSE;
}
break;
case 1: /* UINT16 */
{
UINT16 sval = freerdp_settings_get_uint16(src, cur->id);
if (!freerdp_settings_set_uint16(dst, cur->id, sval))
return FALSE;
}
break;
case 2: /* INT16 */
{
INT16 sval = freerdp_settings_get_int16(src, cur->id);
if (!freerdp_settings_set_int16(dst, cur->id, sval))
return FALSE;
}
break;
case 3: /* UINT32 */
{
UINT32 sval = freerdp_settings_get_uint32(src, cur->id);
if (!freerdp_settings_set_uint32(dst, cur->id, sval))
return FALSE;
}
break;
case 4: /* INT32 */
{
INT32 sval = freerdp_settings_get_int32(src, cur->id);
if (!freerdp_settings_set_int32(dst, cur->id, sval))
return FALSE;
}
break;
case 5: /* UINT64 */
{
UINT64 sval = freerdp_settings_get_uint64(src, cur->id);
if (!freerdp_settings_set_uint64(dst, cur->id, sval))
return FALSE;
}
break;
case 6: /* INT64 */
{
INT64 sval = freerdp_settings_get_int64(src, cur->id);
if (!freerdp_settings_set_int64(dst, cur->id, sval))
return FALSE;
}
break;
case 7: /* strings */
{
const char* sval = freerdp_settings_get_string(src, cur->id);
if (!freerdp_settings_set_string_(dst, cur->id, sval, FALSE))
return FALSE;
}
break;
case 8: /* pointer */
{
const void* sval = freerdp_settings_get_pointer(src, cur->id);
if (!freerdp_settings_set_pointer(dst, cur->id, sval))
return FALSE;
}
break;
}
}
return TRUE;
}
void freerdp_settings_free_keys(rdpSettings* dst, BOOL cleanup)
{
size_t x;
for (x = 0; x < ARRAYSIZE(settings_map); x++)
{
const struct settings_str_entry* cur = &settings_map[x];
switch (cur->type)
{
case 7: /* strings */
freerdp_settings_set_string_(dst, cur->id, NULL, cleanup);
break;
case 8: /* pointer */
freerdp_settings_set_pointer(dst, cur->id, NULL);
break;
}
}
}
SSIZE_T freerdp_settings_get_key_for_name(const char* value) SSIZE_T freerdp_settings_get_key_for_name(const char* value)
{ {
size_t x; size_t x;

View File

@ -40,6 +40,8 @@
#include <freerdp/build-config.h> #include <freerdp/build-config.h>
#include <ctype.h> #include <ctype.h>
#include "settings.h"
#ifdef _WIN32 #ifdef _WIN32
#pragma warning(push) #pragma warning(push)
#pragma warning(disable : 4244) #pragma warning(disable : 4244)
@ -626,39 +628,15 @@ out_fail:
static void freerdp_settings_free_internal(rdpSettings* settings) static void freerdp_settings_free_internal(rdpSettings* settings)
{ {
free(settings->ServerHostname);
free(settings->Username);
free(settings->Password);
free(settings->Domain);
free(settings->PasswordHash);
free(settings->AcceptedCert);
free(settings->AlternateShell);
free(settings->ShellWorkingDirectory);
free(settings->ComputerName);
free(settings->ChannelDefArray); free(settings->ChannelDefArray);
free(settings->MonitorDefArray); free(settings->MonitorDefArray);
free(settings->MonitorIds); free(settings->MonitorIds);
free(settings->ClientAddress);
free(settings->ClientDir);
free(settings->AllowedTlsCiphers);
free(settings->NtlmSamFile);
free(settings->CertificateFile);
free(settings->PrivateKeyFile);
free(settings->ConnectionFile);
free(settings->AssistanceFile);
free(settings->ReceivedCapabilities); free(settings->ReceivedCapabilities);
free(settings->OrderSupport); free(settings->OrderSupport);
free(settings->ClientHostname);
free(settings->ClientProductId);
free(settings->ServerRandom); free(settings->ServerRandom);
free(settings->ClientRandom); free(settings->ClientRandom);
free(settings->ServerCertificate); free(settings->ServerCertificate);
free(settings->RdpKeyFile);
certificate_free(settings->RdpServerCertificate); certificate_free(settings->RdpServerCertificate);
free(settings->CertificateContent);
free(settings->PrivateKeyContent);
free(settings->RdpKeyContent);
free(settings->CertificateAcceptedFingerprints);
free(settings->ClientAutoReconnectCookie); free(settings->ClientAutoReconnectCookie);
free(settings->ServerAutoReconnectCookie); free(settings->ServerAutoReconnectCookie);
free(settings->ClientTimeZone); free(settings->ClientTimeZone);
@ -666,52 +644,21 @@ static void freerdp_settings_free_internal(rdpSettings* settings)
free(settings->GlyphCache); free(settings->GlyphCache);
free(settings->FragCache); free(settings->FragCache);
key_free(settings->RdpServerRsaKey); key_free(settings->RdpServerRsaKey);
free(settings->ConfigPath);
free(settings->CurrentPath);
free(settings->HomePath);
free(settings->LoadBalanceInfo); free(settings->LoadBalanceInfo);
free(settings->TargetNetAddress);
free(settings->RedirectionTargetFQDN);
free(settings->RedirectionTargetNetBiosName);
free(settings->RedirectionUsername);
free(settings->RedirectionDomain);
free(settings->RedirectionPassword); free(settings->RedirectionPassword);
free(settings->RedirectionTsvUrl); free(settings->RedirectionTsvUrl);
free(settings->RedirectionAcceptedCert);
free(settings->RemoteAssistanceSessionId);
free(settings->RemoteAssistancePassword);
free(settings->RemoteAssistancePassStub);
free(settings->RemoteAssistanceRCTicket);
free(settings->AuthenticationServiceClass);
free(settings->GatewayHostname);
free(settings->GatewayUsername);
free(settings->GatewayPassword);
free(settings->GatewayDomain);
free(settings->GatewayAccessToken);
free(settings->GatewayAcceptedCert);
free(settings->CertificateName);
free(settings->DynamicDSTTimeZoneKeyName);
free(settings->PreconnectionBlob);
free(settings->KerberosKdc);
free(settings->KerberosRealm);
free(settings->DumpRemoteFxFile);
free(settings->PlayRemoteFxFile);
free(settings->RemoteApplicationName);
free(settings->RemoteApplicationIcon);
free(settings->RemoteApplicationProgram);
free(settings->RemoteApplicationFile);
free(settings->RemoteApplicationGuid);
free(settings->RemoteApplicationCmdLine);
free(settings->ImeFileName);
free(settings->DrivesToRedirect);
free(settings->WindowTitle);
free(settings->WmClass);
free(settings->ActionScript);
freerdp_target_net_addresses_free(settings); freerdp_target_net_addresses_free(settings);
freerdp_device_collection_free(settings); freerdp_device_collection_free(settings);
freerdp_static_channel_collection_free(settings); freerdp_static_channel_collection_free(settings);
freerdp_dynamic_channel_collection_free(settings); freerdp_dynamic_channel_collection_free(settings);
memset(settings, 0, sizeof(rdpSettings));
/* Extensions */
free(settings->ActionScript);
settings->ActionScript = NULL;
/* Free all strings, set other pointers NULL */
freerdp_settings_free_keys(settings, TRUE);
} }
void freerdp_settings_free(rdpSettings* settings) void freerdp_settings_free(rdpSettings* settings)
@ -723,79 +670,13 @@ void freerdp_settings_free(rdpSettings* settings)
free(settings); free(settings);
} }
BOOL freerdp_settings_copy(rdpSettings* _settings, const rdpSettings* settings) static BOOL freerdp_settings_int_buffer_copy(rdpSettings* _settings, const rdpSettings* settings)
{ {
BOOL rc = FALSE;
UINT32 index; UINT32 index;
if (!settings || !_settings) if (!_settings || !settings)
return FALSE; return FALSE;
freerdp_settings_free_internal(_settings);
*_settings = *settings;
/* char* values */
#define CHECKED_STRDUP(name) \
if (settings->name && !(_settings->name = _strdup(settings->name))) \
goto out_fail
CHECKED_STRDUP(ServerHostname); /* 20 */
CHECKED_STRDUP(Username); /* 21 */
CHECKED_STRDUP(Password); /* 22 */
CHECKED_STRDUP(Domain); /* 23 */
CHECKED_STRDUP(PasswordHash); /* 24 */
CHECKED_STRDUP(AcceptedCert); /* 27 */
CHECKED_STRDUP(AlternateShell); /* 640 */
CHECKED_STRDUP(ShellWorkingDirectory); /* 641 */
CHECKED_STRDUP(ClientAddress); /* 769 */
CHECKED_STRDUP(ClientDir); /* 770 */
CHECKED_STRDUP(DynamicDSTTimeZoneKeyName); /* 897 */
CHECKED_STRDUP(RemoteAssistanceSessionId); /* 1025 */
CHECKED_STRDUP(RemoteAssistancePassStub); /* 1026 */
CHECKED_STRDUP(RemoteAssistancePassword); /* 1027 */
CHECKED_STRDUP(RemoteAssistanceRCTicket); /* 1028 */
CHECKED_STRDUP(AuthenticationServiceClass); /* 1098 */
CHECKED_STRDUP(AllowedTlsCiphers); /* 1101 */
CHECKED_STRDUP(NtlmSamFile); /* 1103 */
CHECKED_STRDUP(PreconnectionBlob); /* 1155 */
CHECKED_STRDUP(TargetNetAddress); /* 1217 */
CHECKED_STRDUP(RedirectionUsername); /* 1220 */
CHECKED_STRDUP(RedirectionDomain); /* 1221 */
CHECKED_STRDUP(RedirectionTargetFQDN); /* 1224 */
CHECKED_STRDUP(RedirectionTargetNetBiosName); /* 1225 */
CHECKED_STRDUP(RedirectionAcceptedCert); /* 1231 */
CHECKED_STRDUP(KerberosKdc); /* 1344 */
CHECKED_STRDUP(KerberosRealm); /* 1345 */
CHECKED_STRDUP(CertificateName); /* 1409 */
CHECKED_STRDUP(CertificateFile); /* 1410 */
CHECKED_STRDUP(PrivateKeyFile); /* 1411 */
CHECKED_STRDUP(RdpKeyFile); /* 1412 */
CHECKED_STRDUP(CertificateContent); /* 1416 */
CHECKED_STRDUP(PrivateKeyContent); /* 1417 */
CHECKED_STRDUP(RdpKeyContent); /* 1418 */
CHECKED_STRDUP(WindowTitle); /* 1542 */
CHECKED_STRDUP(WmClass); /* 1549 */
CHECKED_STRDUP(ComputerName); /* 1664 */
CHECKED_STRDUP(ConnectionFile); /* 1728 */
CHECKED_STRDUP(AssistanceFile); /* 1729 */
CHECKED_STRDUP(HomePath); /* 1792 */
CHECKED_STRDUP(ConfigPath); /* 1793 */
CHECKED_STRDUP(CurrentPath); /* 1794 */
CHECKED_STRDUP(DumpRemoteFxFile); /* 1858 */
CHECKED_STRDUP(PlayRemoteFxFile); /* 1859 */
CHECKED_STRDUP(GatewayHostname); /* 1986 */
CHECKED_STRDUP(GatewayUsername); /* 1987 */
CHECKED_STRDUP(GatewayPassword); /* 1988 */
CHECKED_STRDUP(GatewayDomain); /* 1989 */
CHECKED_STRDUP(GatewayAccessToken); /* 1997 */
CHECKED_STRDUP(GatewayAcceptedCert); /* 1998 */
CHECKED_STRDUP(ProxyHostname); /* 2016 */
CHECKED_STRDUP(RemoteApplicationName); /* 2113 */
CHECKED_STRDUP(RemoteApplicationIcon); /* 2114 */
CHECKED_STRDUP(RemoteApplicationProgram); /* 2115 */
CHECKED_STRDUP(RemoteApplicationFile); /* 2116 */
CHECKED_STRDUP(RemoteApplicationGuid); /* 2117 */
CHECKED_STRDUP(RemoteApplicationCmdLine); /* 2118 */
CHECKED_STRDUP(ImeFileName); /* 2628 */
CHECKED_STRDUP(DrivesToRedirect); /* 4290 */
CHECKED_STRDUP(ActionScript);
if (settings->LoadBalanceInfo && settings->LoadBalanceInfoLength) if (settings->LoadBalanceInfo && settings->LoadBalanceInfoLength)
{ {
@ -902,15 +783,6 @@ BOOL freerdp_settings_copy(rdpSettings* _settings, const rdpSettings* settings)
CopyMemory(_settings->ReceivedCapabilities, settings->ReceivedCapabilities, 32); CopyMemory(_settings->ReceivedCapabilities, settings->ReceivedCapabilities, 32);
CopyMemory(_settings->OrderSupport, settings->OrderSupport, 32); CopyMemory(_settings->OrderSupport, settings->OrderSupport, 32);
_settings->ClientHostname = _strdup(settings->ClientHostname);
if (!_settings->ClientHostname)
goto out_fail;
_settings->ClientProductId = _strdup(settings->ClientProductId);
if (!_settings->ClientProductId)
goto out_fail;
_settings->BitmapCacheV2CellInfo = _settings->BitmapCacheV2CellInfo =
(BITMAP_CACHE_V2_CELL_INFO*)malloc(sizeof(BITMAP_CACHE_V2_CELL_INFO) * 6); (BITMAP_CACHE_V2_CELL_INFO*)malloc(sizeof(BITMAP_CACHE_V2_CELL_INFO) * 6);
@ -933,16 +805,6 @@ BOOL freerdp_settings_copy(rdpSettings* _settings, const rdpSettings* settings)
CopyMemory(_settings->GlyphCache, settings->GlyphCache, sizeof(GLYPH_CACHE_DEFINITION) * 10); CopyMemory(_settings->GlyphCache, settings->GlyphCache, sizeof(GLYPH_CACHE_DEFINITION) * 10);
CopyMemory(_settings->FragCache, settings->FragCache, sizeof(GLYPH_CACHE_DEFINITION)); CopyMemory(_settings->FragCache, settings->FragCache, sizeof(GLYPH_CACHE_DEFINITION));
if (settings->CertificateContent)
_settings->CertificateContent = _strdup(settings->CertificateContent);
if (settings->PrivateKeyContent)
_settings->PrivateKeyContent = _strdup(settings->PrivateKeyContent);
if (settings->RdpKeyContent)
_settings->RdpKeyContent = _strdup(settings->RdpKeyContent);
if (settings->CertificateAcceptedFingerprints)
_settings->CertificateAcceptedFingerprints =
_strdup(settings->CertificateAcceptedFingerprints);
_settings->ClientAutoReconnectCookie = _settings->ClientAutoReconnectCookie =
(ARC_CS_PRIVATE_PACKET*)malloc(sizeof(ARC_CS_PRIVATE_PACKET)); (ARC_CS_PRIVATE_PACKET*)malloc(sizeof(ARC_CS_PRIVATE_PACKET));
@ -1119,6 +981,55 @@ BOOL freerdp_settings_copy(rdpSettings* _settings, const rdpSettings* settings)
goto out_fail; goto out_fail;
} }
if (settings->ActionScript)
_settings->ActionScript = _strdup(settings->ActionScript);
rc = TRUE;
out_fail:
return rc;
}
BOOL freerdp_settings_copy(rdpSettings* _settings, const rdpSettings* settings)
{
BOOL rc;
if (!settings || !_settings)
return FALSE;
/* This is required to free all non string buffers */
freerdp_settings_free_internal(_settings);
/* This copies everything except allocated non string buffers. reset all allocated buffers to
* NULL to fix issues during cleanup */
rc = freerdp_settings_clone_keys(_settings, settings);
_settings->LoadBalanceInfo = NULL;
_settings->ServerRandom = NULL;
_settings->ClientRandom = NULL;
_settings->RdpServerCertificate = NULL;
_settings->RdpServerRsaKey = NULL;
_settings->ChannelDefArray = NULL;
_settings->MonitorDefArray = NULL;
_settings->MonitorIds = NULL;
_settings->ReceivedCapabilities = NULL;
_settings->OrderSupport = NULL;
_settings->BitmapCacheV2CellInfo = NULL;
_settings->GlyphCache = NULL;
_settings->FragCache = NULL;
_settings->ClientAutoReconnectCookie = NULL;
_settings->ServerAutoReconnectCookie = NULL;
_settings->ClientTimeZone = NULL;
_settings->RedirectionPassword = NULL;
_settings->RedirectionTsvUrl = NULL;
_settings->TargetNetAddresses = NULL;
_settings->DeviceArray = NULL;
_settings->StaticChannelArray = NULL;
_settings->DynamicChannelArray = NULL;
_settings->ActionScript = NULL;
if (!rc)
goto out_fail;
/* Begin copying */
if (!freerdp_settings_int_buffer_copy(_settings, settings))
goto out_fail;
return TRUE; return TRUE;
out_fail: out_fail:
freerdp_settings_free_internal(_settings); freerdp_settings_free_internal(_settings);
@ -1134,13 +1045,7 @@ rdpSettings* freerdp_settings_clone(const rdpSettings* settings)
return _settings; return _settings;
out_fail: out_fail:
/* In case any memory allocation failed during clone, some bytes might leak. freerdp_settings_free(_settings);
*
* freerdp_settings_free can't be reliable used at this point since it could
* free memory of pointers copied by CopyMemory and detecting and freeing
* each allocation separately is quite painful.
*/
free(_settings);
return NULL; return NULL;
} }
#ifdef _WIN32 #ifdef _WIN32

View File

@ -26,5 +26,10 @@
#include <freerdp/api.h> #include <freerdp/api.h>
FREERDP_LOCAL BOOL freerdp_settings_set_default_order_support(rdpSettings* settings); FREERDP_LOCAL BOOL freerdp_settings_set_default_order_support(rdpSettings* settings);
FREERDP_LOCAL BOOL freerdp_settings_set_pointer(rdpSettings* dst, size_t index, const void* ptr);
FREERDP_LOCAL BOOL freerdp_settings_clone_keys(rdpSettings* dst, const rdpSettings* src);
FREERDP_LOCAL void freerdp_settings_free_keys(rdpSettings* dst, BOOL cleanup);
FREERDP_LOCAL BOOL freerdp_settings_set_string_(rdpSettings* settings, size_t id, const char* val,
BOOL cleanup);
#endif /* FREERDP_LIB_CORE_SETTINGS_H */ #endif /* FREERDP_LIB_CORE_SETTINGS_H */

View File

@ -6,7 +6,8 @@ int TestSettings(int argc, char* argv[])
int rc = -1; int rc = -1;
size_t x; size_t x;
rdpSettings* settings = NULL; rdpSettings* settings = NULL;
rdpSettings* cloned; rdpSettings* cloned = NULL;
rdpSettings* cloned2 = NULL;
WINPR_UNUSED(argc); WINPR_UNUSED(argc);
WINPR_UNUSED(argv); WINPR_UNUSED(argv);
settings = freerdp_settings_new(0); settings = freerdp_settings_new(0);
@ -17,24 +18,29 @@ int TestSettings(int argc, char* argv[])
return -1; return -1;
} }
settings->Username = _strdup("abcdefg"); if (!freerdp_settings_set_string(settings, FreeRDP_Username, "abcdefg"))
settings->Password = _strdup("xyz"); goto fail;
if (!freerdp_settings_set_string(settings, FreeRDP_Password, "xyz"))
goto fail;
cloned = freerdp_settings_clone(settings); cloned = freerdp_settings_clone(settings);
if (!cloned) if (!cloned)
{ goto fail;
printf("Problem cloning settings\n");
freerdp_settings_free(settings);
return -1;
}
#if defined(have_bool_list_indices) #if defined(have_bool_list_indices)
for (x = 0; x < ARRAYSIZE(bool_list_indices); x++) for (x = 0; x < ARRAYSIZE(bool_list_indices); x++)
{ {
const size_t key = bool_list_indices[x]; const size_t key = bool_list_indices[x];
const char* name = freerdp_settings_get_name_for_key(key);
const BOOL val = freerdp_settings_get_bool(settings, key); const BOOL val = freerdp_settings_get_bool(settings, key);
const BOOL cval = freerdp_settings_get_bool(cloned, key);
if (val != cval)
{
printf("mismatch for key %s: %u -> copy %u\n", name, val, cval);
goto fail;
}
if (!freerdp_settings_set_bool(settings, key, val)) if (!freerdp_settings_set_bool(settings, key, val))
goto fail; goto fail;
} }
@ -45,8 +51,14 @@ int TestSettings(int argc, char* argv[])
for (x = 0; x < ARRAYSIZE(int16_list_indices); x++) for (x = 0; x < ARRAYSIZE(int16_list_indices); x++)
{ {
const size_t key = int16_list_indices[x]; const size_t key = int16_list_indices[x];
const char* name = freerdp_settings_get_name_for_key(key);
const INT16 val = freerdp_settings_get_int16(settings, key); const INT16 val = freerdp_settings_get_int16(settings, key);
const INT16 cval = freerdp_settings_get_int16(cloned, key);
if (val != cval)
{
printf("mismatch for key %s: %" PRId16 " -> copy %" PRId16 "\n", name, val, cval);
goto fail;
}
if (!freerdp_settings_set_int16(settings, key, val)) if (!freerdp_settings_set_int16(settings, key, val))
goto fail; goto fail;
} }
@ -57,8 +69,14 @@ int TestSettings(int argc, char* argv[])
for (x = 0; x < ARRAYSIZE(uint16_list_indices); x++) for (x = 0; x < ARRAYSIZE(uint16_list_indices); x++)
{ {
const size_t key = uint16_list_indices[x]; const size_t key = uint16_list_indices[x];
const char* name = freerdp_settings_get_name_for_key(key);
const UINT16 val = freerdp_settings_get_uint16(settings, key); const UINT16 val = freerdp_settings_get_uint16(settings, key);
const UINT16 cval = freerdp_settings_get_uint16(cloned, key);
if (val != cval)
{
printf("mismatch for key %s: %" PRIu16 " -> copy %" PRIu16 "\n", name, val, cval);
goto fail;
}
if (!freerdp_settings_set_uint16(settings, key, val)) if (!freerdp_settings_set_uint16(settings, key, val))
goto fail; goto fail;
} }
@ -69,8 +87,14 @@ int TestSettings(int argc, char* argv[])
for (x = 0; x < ARRAYSIZE(uint32_list_indices); x++) for (x = 0; x < ARRAYSIZE(uint32_list_indices); x++)
{ {
const size_t key = uint32_list_indices[x]; const size_t key = uint32_list_indices[x];
const char* name = freerdp_settings_get_name_for_key(key);
const UINT32 val = freerdp_settings_get_uint32(settings, key); const UINT32 val = freerdp_settings_get_uint32(settings, key);
const UINT32 cval = freerdp_settings_get_uint32(cloned, key);
if (val != cval)
{
printf("mismatch for key %s: %" PRIu32 " -> copy %" PRIu32 "\n", name, val, cval);
goto fail;
}
if (!freerdp_settings_set_uint32(settings, key, val)) if (!freerdp_settings_set_uint32(settings, key, val))
goto fail; goto fail;
} }
@ -81,8 +105,14 @@ int TestSettings(int argc, char* argv[])
for (x = 0; x < ARRAYSIZE(int32_list_indices); x++) for (x = 0; x < ARRAYSIZE(int32_list_indices); x++)
{ {
const size_t key = int32_list_indices[x]; const size_t key = int32_list_indices[x];
const char* name = freerdp_settings_get_name_for_key(key);
const INT32 val = freerdp_settings_get_int32(settings, key); const INT32 val = freerdp_settings_get_int32(settings, key);
const INT32 cval = freerdp_settings_get_int32(cloned, key);
if (val != cval)
{
printf("mismatch for key %s: %" PRId32 " -> copy %" PRId32 "\n", name, val, cval);
goto fail;
}
if (!freerdp_settings_set_int32(settings, key, val)) if (!freerdp_settings_set_int32(settings, key, val))
goto fail; goto fail;
} }
@ -93,8 +123,14 @@ int TestSettings(int argc, char* argv[])
for (x = 0; x < ARRAYSIZE(uint64_list_indices); x++) for (x = 0; x < ARRAYSIZE(uint64_list_indices); x++)
{ {
const size_t key = uint64_list_indices[x]; const size_t key = uint64_list_indices[x];
const char* name = freerdp_settings_get_name_for_key(key);
const UINT64 val = freerdp_settings_get_uint64(settings, key); const UINT64 val = freerdp_settings_get_uint64(settings, key);
const UINT64 cval = freerdp_settings_get_uint64(cloned, key);
if (val != cval)
{
printf("mismatch for key %s: %" PRIu64 " -> copy %" PRIu64 "\n", name, val, cval);
goto fail;
}
if (!freerdp_settings_set_uint64(settings, key, val)) if (!freerdp_settings_set_uint64(settings, key, val))
goto fail; goto fail;
} }
@ -105,8 +141,14 @@ int TestSettings(int argc, char* argv[])
for (x = 0; x < ARRAYSIZE(int64_list_indices); x++) for (x = 0; x < ARRAYSIZE(int64_list_indices); x++)
{ {
const size_t key = int64_list_indices[x]; const size_t key = int64_list_indices[x];
const char* name = freerdp_settings_get_name_for_key(key);
const INT64 val = freerdp_settings_get_int64(settings, key); const INT64 val = freerdp_settings_get_int64(settings, key);
const INT64 cval = freerdp_settings_get_int64(cloned, key);
if (val != cval)
{
printf("mismatch for key %s: %" PRId64 " -> copy %" PRId64 "\n", name, val, cval);
goto fail;
}
if (!freerdp_settings_set_int64(settings, key, val)) if (!freerdp_settings_set_int64(settings, key, val))
goto fail; goto fail;
} }
@ -119,7 +161,14 @@ int TestSettings(int argc, char* argv[])
const size_t key = string_list_indices[x]; const size_t key = string_list_indices[x];
const char val[] = "test-string"; const char val[] = "test-string";
const char* res; const char* res;
const char* name = freerdp_settings_get_name_for_key(key);
const char* oval = freerdp_settings_get_string(settings, key);
const char* cval = freerdp_settings_get_string(cloned, key);
if ((oval != cval) && (strcmp(oval, cval) != 0))
{
printf("mismatch for key %s: %s -> copy %s\n", name, oval, cval);
goto fail;
}
if (!freerdp_settings_set_string(settings, key, val)) if (!freerdp_settings_set_string(settings, key, val))
goto fail; goto fail;
@ -139,9 +188,16 @@ int TestSettings(int argc, char* argv[])
} }
#endif #endif
cloned2 = freerdp_settings_clone(settings);
if (!cloned2)
goto fail;
if (!freerdp_settings_copy(cloned2, cloned))
goto fail;
rc = 0; rc = 0;
fail: fail:
freerdp_settings_free(cloned); freerdp_settings_free(cloned);
freerdp_settings_free(cloned2);
freerdp_settings_free(settings); freerdp_settings_free(settings);
return rc; return rc;
} }

View File

@ -49,6 +49,103 @@ def write_str(f, entry_dict):
for val in values: for val in values:
write_str_case(f, entry_types.index(entry_type), val) write_str_case(f, entry_types.index(entry_type), val)
f.write('};\n\n') f.write('};\n\n')
f.write('\n')
f.write('BOOL freerdp_settings_clone_keys(rdpSettings* dst, const rdpSettings* src)\n')
f.write('{\n')
f.write('\tsize_t x;\n')
f.write('\tfor(x=0; x<ARRAYSIZE(settings_map); x++)\n')
f.write('\t{\n')
f.write('\t\tconst struct settings_str_entry* cur = &settings_map[x];\n')
f.write('\t\tswitch(cur->type)\n')
f.write('\t\t{\n')
f.write('\t\t\tcase 0: /* bool */\n')
f.write('\t\t\t{\n')
f.write('\t\t\t\tBOOL sval = freerdp_settings_get_bool(src, cur->id);\n')
f.write('\t\t\t\tif (!freerdp_settings_set_bool(dst, cur->id, sval))\n')
f.write('\t\t\t\t\treturn FALSE;\n')
f.write('\t\t\t}\n')
f.write('\t\t\tbreak;\n')
f.write('\t\t\tcase 1: /* UINT16 */\n')
f.write('\t\t\t{\n')
f.write('\t\t\t\tUINT16 sval = freerdp_settings_get_uint16(src, cur->id);\n')
f.write('\t\t\t\tif (!freerdp_settings_set_uint16(dst, cur->id, sval))\n')
f.write('\t\t\t\t\treturn FALSE;\n')
f.write('\t\t\t}\n')
f.write('\t\t\tbreak;\n')
f.write('\t\t\tcase 2: /* INT16 */\n')
f.write('\t\t\t{\n')
f.write('\t\t\t\tINT16 sval = freerdp_settings_get_int16(src, cur->id);\n')
f.write('\t\t\t\tif (!freerdp_settings_set_int16(dst, cur->id, sval))\n')
f.write('\t\t\t\t\treturn FALSE;\n')
f.write('\t\t\t}\n')
f.write('\t\t\tbreak;\n')
f.write('\t\t\tcase 3: /* UINT32 */\n')
f.write('\t\t\t{\n')
f.write('\t\t\t\tUINT32 sval = freerdp_settings_get_uint32(src, cur->id);\n')
f.write('\t\t\t\tif (!freerdp_settings_set_uint32(dst, cur->id, sval))\n')
f.write('\t\t\t\t\treturn FALSE;\n')
f.write('\t\t\t}\n')
f.write('\t\t\tbreak;\n')
f.write('\t\t\tcase 4: /* INT32 */\n')
f.write('\t\t\t{\n')
f.write('\t\t\t\tINT32 sval = freerdp_settings_get_int32(src, cur->id);\n')
f.write('\t\t\t\tif (!freerdp_settings_set_int32(dst, cur->id, sval))\n')
f.write('\t\t\t\t\treturn FALSE;\n')
f.write('\t\t\t}\n')
f.write('\t\t\tbreak;\n')
f.write('\t\t\tcase 5: /* UINT64 */\n')
f.write('\t\t\t{\n')
f.write('\t\t\t\tUINT64 sval = freerdp_settings_get_uint64(src, cur->id);\n')
f.write('\t\t\t\tif (!freerdp_settings_set_uint64(dst, cur->id, sval))\n')
f.write('\t\t\t\t\treturn FALSE;\n')
f.write('\t\t\t}\n')
f.write('\t\t\tbreak;\n')
f.write('\t\t\tcase 6: /* INT64 */\n')
f.write('\t\t\t{\n')
f.write('\t\t\t\tINT64 sval = freerdp_settings_get_int64(src, cur->id);\n')
f.write('\t\t\t\tif (!freerdp_settings_set_int64(dst, cur->id, sval))\n')
f.write('\t\t\t\t\treturn FALSE;\n')
f.write('\t\t\t}\n')
f.write('\t\t\tbreak;\n')
f.write('\t\t\tcase 7: /* strings */\n')
f.write('\t\t\t{\n')
f.write('\t\t\t\tconst char* sval = freerdp_settings_get_string(src, cur->id);\n')
f.write('\t\t\t\tif (!freerdp_settings_set_string_(dst, cur->id, sval, FALSE))\n')
f.write('\t\t\t\t\treturn FALSE;\n')
f.write('\t\t\t}\n')
f.write('\t\t\tbreak;\n')
f.write('\t\t\tcase 8: /* pointer */\n')
f.write('\t\t\t{\n')
f.write('\t\t\t\tconst void* sval = freerdp_settings_get_pointer(src, cur->id);\n')
f.write('\t\t\t\tif (!freerdp_settings_set_pointer(dst, cur->id, sval))\n')
f.write('\t\t\t\t\treturn FALSE;\n')
f.write('\t\t\t}\n')
f.write('\t\t\tbreak;\n')
f.write('\t\t}\n')
f.write('\t}\n')
f.write('\treturn TRUE;\n')
f.write('}\n')
f.write('\n')
f.write('void freerdp_settings_free_keys(rdpSettings* dst, BOOL cleanup)\n')
f.write('{\n')
f.write('\tsize_t x;\n')
f.write('\tfor(x=0; x<ARRAYSIZE(settings_map); x++)\n')
f.write('\t{\n')
f.write('\t\tconst struct settings_str_entry* cur = &settings_map[x];\n')
f.write('\t\tswitch(cur->type)\n')
f.write('\t\t{\n')
f.write('\t\t\tcase 7: /* strings */\n')
f.write('\t\t\t\tfreerdp_settings_set_string_(dst, cur->id, NULL, cleanup);\n')
f.write('\t\t\tbreak;\n')
f.write('\t\t\tcase 8: /* pointer */\n')
f.write('\t\t\t\tfreerdp_settings_set_pointer(dst, cur->id, NULL);\n')
f.write('\t\t\tbreak;\n')
f.write('\t\t}\n')
f.write('\t}\n')
f.write('}\n')
f.write('\n')
f.write('SSIZE_T freerdp_settings_get_key_for_name(const char* value)\n') f.write('SSIZE_T freerdp_settings_get_key_for_name(const char* value)\n')
f.write('{\n') f.write('{\n')
f.write('\tsize_t x;\n') f.write('\tsize_t x;\n')
@ -130,11 +227,15 @@ def write_getter(f, entry_dict, entry_type, entry_name):
def write_setter_case(f, val, isString, isPointer): def write_setter_case(f, val, isString, isPointer):
f.write('\t\tcase FreeRDP_' + val + ':\n') f.write('\t\tcase FreeRDP_' + val + ':\n')
if not isString: if isPointer:
f.write('\t\t\tsettings->' + val + ' = (void*)val;\n')
f.write('\t\t\tbreak;\n\n')
elif not isString:
f.write('\t\t\tsettings->' + val + ' = val;\n') f.write('\t\t\tsettings->' + val + ' = val;\n')
f.write('\t\t\tbreak;\n\n') f.write('\t\t\tbreak;\n\n')
else: else:
f.write('\t\t\tfree(settings->' + val + ');\n') f.write('\t\t\tif (cleanup)\n')
f.write('\t\t\t\tfree(settings->' + val + ');\n')
f.write('\t\t\tsettings->' + val + ' = (val ? _strdup(val) : NULL);\n') f.write('\t\t\tsettings->' + val + ' = (val ? _strdup(val) : NULL);\n')
f.write('\t\t\treturn (!val || settings->' + val + ' != NULL);\n\n') f.write('\t\t\treturn (!val || settings->' + val + ' != NULL);\n\n')
@ -143,13 +244,20 @@ def write_setter(f, entry_dict, entry_type, entry_name):
isPointer = 'pointer' in entry_name isPointer = 'pointer' in entry_name
values = get_values(entry_dict, entry_type) values = get_values(entry_dict, entry_type)
f.write('BOOL freerdp_settings_set_' + entry_name.lower() + '(rdpSettings* settings, size_t id, ') f.write('BOOL freerdp_settings_set_' + entry_name.lower())
if isString:
f.write('_')
f.write('(rdpSettings* settings, size_t id, ')
if isString or isPointer: if isString or isPointer:
f.write('const ') f.write('const ')
if not isPointer: if not isPointer:
f.write(entry_type + ' val)\n') f.write(entry_type + ' val')
else: else:
f.write('void* val)\n') f.write('void* val')
if isString:
f.write(', BOOL cleanup)\n')
else:
f.write(')\n')
f.write('{\n') f.write('{\n')
f.write('\tif (!settings)\n') f.write('\tif (!settings)\n')
f.write('\t\treturn FALSE;\n\n') f.write('\t\treturn FALSE;\n\n')
@ -164,6 +272,20 @@ def write_setter(f, entry_dict, entry_type, entry_name):
f.write('\t}\n') f.write('\t}\n')
f.write('\treturn TRUE;\n') f.write('\treturn TRUE;\n')
f.write('}\n\n') f.write('}\n\n')
f.write('\n')
if isString:
f.write('BOOL freerdp_settings_set_' + entry_name.lower() + '(rdpSettings* settings, size_t id, ')
if isString or isPointer:
f.write('const ')
if not isPointer:
f.write(entry_type + ' val')
else:
f.write('void* val')
f.write(')\n')
f.write('{\n')
f.write('\treturn freerdp_settings_set_' + entry_name.lower() + '_(settings, id, val, TRUE);\n')
f.write('}\n')
f.write('\n')
name = os.path.dirname(os.path.realpath(__file__)) name = os.path.dirname(os.path.realpath(__file__))
begin = "WARNING: this data structure is carefully padded for ABI stability!" begin = "WARNING: this data structure is carefully padded for ABI stability!"
@ -230,7 +352,7 @@ try:
write_getter(f, getter_list, 'char*', 'string') write_getter(f, getter_list, 'char*', 'string')
write_setter(f, setter_list, 'char*', 'string') write_setter(f, setter_list, 'char*', 'string')
write_getter(f, getter_list, '*', 'pointer') write_getter(f, getter_list, '*', 'pointer')
# write_setter(f, setter_list, '*', 'pointer') write_setter(f, setter_list, '*', 'pointer')
f.write('\n') f.write('\n')
@ -238,6 +360,7 @@ try:
f.write('/* Generated by ' + '' + ' */\n\n') f.write('/* Generated by ' + '' + ' */\n\n')
f.write('#include <freerdp/settings.h>\n') f.write('#include <freerdp/settings.h>\n')
f.write('#include <freerdp/log.h>\n\n') f.write('#include <freerdp/log.h>\n\n')
f.write('#include "../core/settings.h"\n\n')
f.write('#define TAG FREERDP_TAG("common.settings")\n\n') f.write('#define TAG FREERDP_TAG("common.settings")\n\n')
getter_list = dict(type_list) getter_list = dict(type_list)