<html>
  <head>
    <meta content="text/html; charset=ISO-8859-1"
      http-equiv="Content-Type">
  </head>
  <body bgcolor="#FFFFFF" text="#000000">
    <div class="moz-cite-prefix">On 03/06/2014 11:12 PM, Sheldon wrote:<br>
    </div>
    <blockquote cite="mid:5318907A.1070406@linux.vnet.ibm.com"
      type="cite">
      <meta content="text/html; charset=ISO-8859-1"
        http-equiv="Content-Type">
      <div class="moz-cite-prefix">On 03/06/2014 10:53 PM, Aline Manera
        wrote:<br>
      </div>
      <blockquote cite="mid:53188BF6.5090308@linux.vnet.ibm.com"
        type="cite">
        <meta content="text/html; charset=ISO-8859-1"
          http-equiv="Content-Type">
        <div class="moz-cite-prefix">On 03/06/2014 06:41 AM, Sheldon
          wrote:<br>
        </div>
        <blockquote cite="mid:531842B9.5020708@linux.vnet.ibm.com"
          type="cite">On 03/05/2014 03:35 AM, Aline Manera wrote: <br>
          <blockquote type="cite">From: Aline Manera <a
              moz-do-not-send="true" class="moz-txt-link-rfc2396E"
              href="mailto:alinefm@br.ibm.com">&lt;alinefm@br.ibm.com&gt;</a>
            <br>
            <br>
            The error message and all its parameters must be string. <br>
            So convert error code to string in order to accomplish it. <br>
            <br>
            Signed-off-by: Aline Manera <a moz-do-not-send="true"
              class="moz-txt-link-rfc2396E"
              href="mailto:alinefm@br.ibm.com">&lt;alinefm@br.ibm.com&gt;</a>
            <br>
            --- <br>
            &nbsp; src/kimchi/auth.py |&nbsp;&nbsp;&nbsp; 2 +- <br>
            &nbsp; 1 file changed, 1 insertion(+), 1 deletion(-) <br>
            <br>
            diff --git a/src/kimchi/auth.py b/src/kimchi/auth.py <br>
            index af3b610..b16f2db 100644 <br>
            --- a/src/kimchi/auth.py <br>
            +++ b/src/kimchi/auth.py <br>
            @@ -107,7 +107,7 @@ def authenticate(username, password,
            service="passwd"): <br>
            &nbsp;&nbsp;&nbsp;&nbsp;&nbsp; try: <br>
            &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; auth.authenticate() <br>
            &nbsp;&nbsp;&nbsp;&nbsp;&nbsp; except PAM.error, (resp, code): <br>
            -&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; msg_args = {'userid': username, 'code': code} <br>
            +&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; msg_args = {'userid': username, 'code': str(code)}
            <br>
            &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; raise OperationFailed("KCHAUTH0001E", msg_args) <br>
            <br>
            &nbsp;&nbsp;&nbsp;&nbsp;&nbsp; return True <br>
          </blockquote>
          How about the follow change? <br>
          It can avoid call str() before we raise KimchiException
          Everywhere. <br>
          Also I think it is not good to other developers to call str
          explicitly Everywhere. <br>
          <br>
          diff --git a/src/kimchi/exception.py b/src/kimchi/exception.py
          <br>
          index 71a4d11..73e88ce 100644 <br>
          --- a/src/kimchi/exception.py <br>
          +++ b/src/kimchi/exception.py <br>
          @@ -50,7 +50,7 @@ class KimchiException(Exception): <br>
          translation = gettext <br>
          <br>
          for key, value in args.iteritems(): <br>
          - if not isinstance(value, unicode): <br>
          + if isinstance(value, str): <br>
          args[key] = unicode(value, 'utf-8') <br>
          <br>
          return unicode(translation.gettext(text), 'utf-8') % args <br>
          <br>
          <br>
          <br>
        </blockquote>
        <br>
        What about always convert to string before to unicode?<br>
        <br>
        if not isinstance(value, unicode):<br>
        &nbsp;&nbsp; args[key] = unicode(<b>str</b>(value), 'utf-8')<br>
      </blockquote>
      This is also OK.&nbsp; seems it is more understand to most python
      developer. <br>
      actually it is same&nbsp; effect with the above code I suggested.<br>
      <br>
      AFAK&#65292; seems two types has no string representation, one is unicode
      and another is object derived from nothing.<br>
    </blockquote>
    sorry, unicode has string representation. but it make no sense.&nbsp; For
    it will raise UnicodeEncodeError. <br>
    <blockquote cite="mid:5318907A.1070406@linux.vnet.ibm.com"
      type="cite"> <br>
      The later object derived from nothing, we can consider it is a
      bug.<br>
      Kimchi do not allowed this.&nbsp;&nbsp; class c1(): pass<br>
      But I'm not worry about it.<br>
      IMO, no one will not pass this instance of object to&nbsp;
      KimchiException as args.<br>
      <br>
      we just allow objects derived from python object class in kimchi,&nbsp;
      class c2(object): pass<br>
      <br>
      <br>
      <br>
      <blockquote cite="mid:53188BF6.5090308@linux.vnet.ibm.com"
        type="cite"> <br>
        That way we guarantee everything will be unicode in the end.<br>
        <br>
      </blockquote>
      <br>
      <br>
      <pre class="moz-signature" cols="72">-- 
Thanks and best regards!

Sheldon Feng(&#20911;&#23569;&#21512;)<a moz-do-not-send="true" class="moz-txt-link-rfc2396E" href="mailto:shaohef@linux.vnet.ibm.com">&lt;shaohef@linux.vnet.ibm.com&gt;</a>
IBM Linux Technology Center</pre>
      <br>
      <fieldset class="mimeAttachmentHeader"></fieldset>
      <br>
      <pre wrap="">_______________________________________________
Kimchi-devel mailing list
<a class="moz-txt-link-abbreviated" href="mailto:Kimchi-devel@ovirt.org">Kimchi-devel@ovirt.org</a>
<a class="moz-txt-link-freetext" href="http://lists.ovirt.org/mailman/listinfo/kimchi-devel">http://lists.ovirt.org/mailman/listinfo/kimchi-devel</a>
</pre>
    </blockquote>
    <br>
    <br>
    <pre class="moz-signature" cols="72">-- 
Thanks and best regards!

Sheldon Feng(&#20911;&#23569;&#21512;)<a class="moz-txt-link-rfc2396E" href="mailto:shaohef@linux.vnet.ibm.com">&lt;shaohef@linux.vnet.ibm.com&gt;</a>
IBM Linux Technology Center</pre>
  </body>
</html>