svn commit: r315901 - head/sbin/devd

Cy Schubert Cy.Schubert at komquats.com
Fri Mar 24 21:32:02 UTC 2017


In message <201703241346.v2ODkQtJ019397 at repo.freebsd.org>, Warner Losh 
writes:
> Author: imp
> Date: Fri Mar 24 13:46:26 2017
> New Revision: 315901
> URL: https://svnweb.freebsd.org/changeset/base/315901
> 
> Log:
>   Use a more stream-lined version of fix_value.
>   
>   Submitted by: ian@
> 
> Modified:
>   head/sbin/devd/devd.cc
>   head/sbin/devd/devd.hh
> 
> Modified: head/sbin/devd/devd.cc
> =============================================================================
> =
> --- head/sbin/devd/devd.cc	Fri Mar 24 11:46:49 2017	(r315900)
> +++ head/sbin/devd/devd.cc	Fri Mar 24 13:46:26 2017	(r315901)
> @@ -417,24 +417,16 @@ var_list::is_set(const string &var) cons
>   * converted to ". For all other characters, both \ and following
>   * character. So the string 'fre\:\"' is translated to 'fred\:"'.
>   */
> -const std::string &
> +std::string
>  var_list::fix_value(const std::string &val) const
>  {
> -	char *tmp, *dst;
> -	const char *src;
> -	std::string *rv;
> -
> -	dst = tmp = new char[val.length()];
> -	src = val.c_str();
> -	while (*src) {
> -		if (*src == '\\' && src[1] == '"')
> -			src++;
> -		else
> -			*dst++ = *src++;
> -	}
> -	rv = new string(tmp);
> -	delete tmp;
> -	return *rv;
> +        std::string rv(val);
> +        std::string::size_type pos(0);
> +
> +        while ((pos = rv.find("\\\"", pos)) != rv.npos) {
> +                rv.erase(pos, 1);
> +        }
> +        return (rv);
>  }
>  
>  void
> 
> Modified: head/sbin/devd/devd.hh
> =============================================================================
> =
> --- head/sbin/devd/devd.hh	Fri Mar 24 11:46:49 2017	(r315900)
> +++ head/sbin/devd/devd.hh	Fri Mar 24 13:46:26 2017	(r315901)
> @@ -57,7 +57,7 @@ public:
>  	static const std::string nothing;
>  
>  private:
> -	const std::string &fix_value(const std::string &val) const;
> +	std::string fix_value(const std::string &val) const;
>  
>  	std::map<std::string, std::string> _vars;
>  };
> 
> 

Thank you Warner.


-- 
Cheers,
Cy Schubert <Cy.Schubert at cschubert.com>
FreeBSD UNIX:  <cy at FreeBSD.org>   Web:  http://www.FreeBSD.org

	The need of the many outweighs the greed of the few.




More information about the svn-src-head mailing list