I don't think it is appropriate to simply copy/paste the jira content into the svn change comment. I expect the jira issue to contain a lot more details and some comments about the change, where I expect the svn change comment to briefly explain the change.

--jason


On Nov 27, 2006, at 9:57 PM, Vamsavardhana Reddy wrote:

Hi Jason,

Sometime ago I had difficulty in figuring out what revision(s) fixed a particular JIRA and vice versa. So, I have made it a practice to include the JIRA number in the change log and svn revision numbers in the JIRA comments so that someone investigating the JIRA or the svn revision will be able to figureout what is happening either from the JIRA or the svn change log without much difficulty. I thought this is complete & sufficient and is definitely an improvement on what was followed earlier. For those revisions that are not related to a JIRA, I have included a description of the change in the change log itself. Since no one had any complaints on this, I have followed it till now. Adding full details (or a summary) of the change to the change log would not be much of a overhead and it amounts to one more Copy+Paste. I agree that adding a summary of changes along with a link to where full details can be found (like the JIRA number) is definitely a further improvement and will be followed from now on. After all, all our efforts are to improve things and make life easy (for a lot of others).

--vamsi

On 11/28/06, Jason Dillon <[EMAIL PROTECTED]> wrote:
Please... please... please... put more context into the commit log.

"MapEditor does not work" tells me nothing about what was actually
changed.  When auditing changes it helps to have some context to the
change in the commit log so that its easy to comprehend what the
change was, with out having to dig around, or bounce into JIRA, etc.

I've mentioned this a few times before... while its is good to
include the JIRA issue ID, only including that ID, or in this case
the ID and the issue subject, in the SVN commit message is not
sufficient.

Please... please... please... try to put some more meaningful context
into commit messages.

Thanks,

--jason


On Nov 27, 2006, at 2:54 AM, [EMAIL PROTECTED] wrote:

> Author: vamsic007
> Date: Mon Nov 27 02:54:38 2006
> New Revision: 479586
>
> URL: http://svn.apache.org/viewvc?view=rev&rev=479586
> Log:
> GERONIMO-2458 MapEditor does not work
>
> Modified:
>     geronimo/server/trunk/modules/geronimo-common/src/main/java/org/
> apache/geronimo/common/propertyeditor/MapEditor.java
>
> Modified: geronimo/server/trunk/modules/geronimo-common/src/main/
> java/org/apache/geronimo/common/propertyeditor/MapEditor.java
> URL: http://svn.apache.org/viewvc/geronimo/server/trunk/modules/
> geronimo-common/src/main/java/org/apache/geronimo/common/
> propertyeditor/MapEditor.java? view=diff&rev=479586&r1=479585&r2=479586 > ======================================================================
> ========
> --- geronimo/server/trunk/modules/geronimo-common/src/main/java/org/
> apache/geronimo/common/propertyeditor/MapEditor.java (original)
> +++ geronimo/server/trunk/modules/geronimo-common/src/main/java/org/
> apache/geronimo/common/propertyeditor/MapEditor.java Mon Nov 27
> 02:54:38 2006
> @@ -19,17 +19,22 @@
>
>  import java.io.ByteArrayInputStream;
>  import java.io.IOException;
> +import java.util.Iterator;
>  import java.util.Properties;
>  import java.util.Map;
>
> +import org.apache.commons.logging.Log ;
> +import org.apache.commons.logging.LogFactory;
> +
>  /**
> - * A property editor for [EMAIL PROTECTED] java.util.Properties}.
> + * A property editor for [EMAIL PROTECTED] java.util.Map}.
>   *
>   * @version $Rev$ $Date$
>   */
>  public class MapEditor
>     extends TextPropertyEditorSupport
>  {
> +    private static final Log log = LogFactory.getLog
> (MapEditor.class);
>      /**
>       *
>       * @throws PropertyEditorException  An IOException occured.
> @@ -50,11 +55,30 @@
>          Map map = (Map) getValue();
>          if (!(map instanceof Properties)) {
>              Properties p = new Properties();
> -            if (map != null) {
> -                p.putAll(map);
> +            if(map != null) {
> +                if(!map.containsKey(null) && !map.containsValue
> (null)) {
> +                    p.putAll(map);
> +                } else {
> +                    // Map contains null keys or values.  Replace
> null with empty string.
> +                    log.warn("Map contains null keys or values.
> Replacing null values with empty string.");
> +                    for(Iterator itr = map.entrySet().iterator();
> itr.hasNext(); ) {
> +                        Map.Entry entry = (Map.Entry) itr.next();
> +                        Object key = entry.getKey();
> +                        Object value = entry.getValue();
> +                        if(key == null) {
> +                            key = "";
> +                        }
> +                        if(value == null) {
> +                            value = "";
> +                        }
> +                        p.put(key, value);
> +                    }
> +                }
> +                map = p;
>              }
> -            map = p;
>          }
> -        return map.toString();
> +        PropertiesEditor pe = new PropertiesEditor();
> +        pe.setValue(map);
> +        return pe.getAsText();
>      }
>  }
>
>



Reply via email to