LabelTask.cs :  » Build-Systems » NAntContrib » NAnt » Contrib » Tasks » StarTeam » C# / CSharp Open Source

Home
C# / CSharp Open Source
1.2.6.4 mono .net core
2.2.6.4 mono core
3.Aspect Oriented Frameworks
4.Bloggers
5.Build Systems
6.Business Application
7.Charting Reporting Tools
8.Chat Servers
9.Code Coverage Tools
10.Content Management Systems CMS
11.CRM ERP
12.Database
13.Development
14.Email
15.Forum
16.Game
17.GIS
18.GUI
19.IDEs
20.Installers Generators
21.Inversion of Control Dependency Injection
22.Issue Tracking
23.Logging Tools
24.Message
25.Mobile
26.Network Clients
27.Network Servers
28.Office
29.PDF
30.Persistence Frameworks
31.Portals
32.Profilers
33.Project Management
34.RSS RDF
35.Rule Engines
36.Script
37.Search Engines
38.Sound Audio
39.Source Control
40.SQL Clients
41.Template Engines
42.Testing
43.UML
44.Web Frameworks
45.Web Service
46.Web Testing
47.Wiki Engines
48.Windows Presentation Foundation
49.Workflows
50.XML Parsers
C# / C Sharp
C# / C Sharp by API
C# / CSharp Tutorial
C# / CSharp Open Source » Build Systems » NAntContrib 
NAntContrib » NAnt » Contrib » Tasks » StarTeam » LabelTask.cs
//
// NAntContrib
// Copyright (C) 2002 Tomas Restrepo (tomasr@mvps.org)
//
// This library is free software; you can redistribute it and/or
// modify it under the terms of the GNU Lesser General Public
// License as published by the Free Software Foundation; either
// version 2.1 of the License, or (at your option) any later version.
//
// This library is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
// Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public
// License along with this library; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
//

using System;
using System.Globalization;
using System.IO;

using InterOpStarTeamStarTeam;

using NAnt.Core;
using NAnt.Core.Attributes;

namespace NAnt.Contrib.Tasks.StarTeam{
    /// <summary>
    /// Allows creation of view labels in StarTeam repositories.
    /// </summary>
    /// <remarks>
    /// <para>Often when building projects you wish to label the source control repository.</para>
    /// <para>By default this task creates view labels with the build option turned on.</para>
    /// <para>This task was ported from the Ant task http://jakarta.apache.org/ant/manual/OptionalTasks/starteam.html#stlabel </para>
    /// <para>You need to have the StarTeam SDK installed for this task to function correctly.</para>
    /// </remarks>
    /// <example>
    ///   <para>Creates a label in a StarTeam repository.</para>
    ///   <code>
    ///     <![CDATA[
    /// <!-- 
    ///   constructs a 'url' containing connection information to pass to the task 
    ///   alternatively you can set each attribute manually 
    /// -->
    /// <property name="ST.url" value="user:pass@serverhost:49201/projectname/viewname" />
    /// <stlabel label="3.1 (label title goes here)" description="This is a label description" url="${ST.url}" />
    ///     ]]>
    ///   </code>
    /// </example>
    abstract public class LabelTask : StarTeamTask {
        /// <summary> 
        /// The name to be given to the label; required.
        /// </summary>
        [TaskAttribute("label", Required=true)]
        public virtual string Label {
            get { return _labelName; }
            set { _labelName = value; }
        }

        /// <summary> Should label be marked build : default is true</summary>
        [TaskAttribute("buildlabel", Required=false)]
        [BooleanValidator]
        public virtual bool BuildLabel {
            set { _isBuildLabel = value; }
        }

        /// <summary> 
        /// Should label created be a revision label. The default is 
        /// <see langword="false" />.
        /// </summary>
        /// <remarks>
        /// <see cref="BuildLabel" /> has no effect if this is set to <see langword="true" />
        /// as revision labels cannot have a build status.
        /// </remarks>
        [TaskAttribute("revisionlabel", Required=false)]
        [BooleanValidator]
        public virtual bool RevisionLabel {
            set { _isRevision = value; }
        }

        /// <summary> Optional description of the label to be stored in the StarTeam project.</summary>
        [TaskAttribute("description", Required=false)]
        public virtual string Description {
            set { _description = value; }
        }

        /// <summary> 
        /// Optional: If this property is set the label will be created as of the datetime specified. 
        /// Please provide a datetime format that can be parsed via 
        /// <see cref="DateTime.Parse(string, IFormatProvider)"/>.
        /// </summary>
        /// <remarks>
        /// This property is ignored when <see cref="RevisionLabel" /> set to 
        /// <see langword="true" />.
        /// </remarks>
        [TaskAttribute("timestamp", Required=false)]
        public virtual string LastBuild {
            set {
                try {
                    _labelAsOfDate = DateTime.Parse(value, CultureInfo.InvariantCulture);
                    _isAsOfDateSet = true;
                } catch (System.FormatException ex) {
                    throw new BuildException(string.Format("Unable to parse '{0}' as datetime.", 
                        value), Location, ex);
                }
            }
        }

        /// <summary> The name of the label to be set in Starteam.</summary>
        protected string _labelName = null;

        /// <summary> The label description to be set in Starteam.</summary>
        protected string _description = null;

        /// <summary> Is the label being created a build label.</summary>
        protected bool _isBuildLabel = true;

        /// <summary> If set the datetime to set the label as of.</summary>
        protected DateTime _labelAsOfDate;

        /// <summary> Kludgy flag to keep track if date has been set. 
        /// Please kill this if you can. Here based on experiences I have had with VB.NET</summary>
        protected bool _isAsOfDateSet = false;

        /// <summary> Does user wish to make a revision label?</summary>
        protected bool _isRevision = false;

        /// <summary> 
        /// Override of base-class abstract function creates an appropriately configured view.  
        /// For labels this a view configured as of this.lastBuild.
        /// </summary>
        /// <param name="raw">the unconfigured <code>View</code></param>
        /// <returns>the snapshot <code>View</code> appropriately configured.</returns>
        protected internal override InterOpStarTeam.StView createSnapshotView(InterOpStarTeam.StView raw) {
            InterOpStarTeam.StView starTeamView;
            InterOpStarTeam.StViewFactory starTeamViewFactory = new InterOpStarTeam.StViewFactory();
            InterOpStarTeam.StViewConfigurationStaticsClass starTeamViewConfiguration = new InterOpStarTeam.StViewConfigurationStaticsClass();
            if(_isAsOfDateSet && !_isRevision) {
                starTeamView = starTeamViewFactory.Create(raw, starTeamViewConfiguration.createFromTime(_labelAsOfDate));
            }
            else {
                starTeamView = starTeamViewFactory.Create(raw, starTeamViewConfiguration.createTip());
            }
            return starTeamView;
        }

        protected virtual InterOpStarTeam.StLabel createLabel(InterOpStarTeam.StView snapshot) {
            InterOpStarTeam.StLabel newLabel;
            InterOpStarTeam.StLabelFactoryClass starTeamLabelFactory = new InterOpStarTeam.StLabelFactoryClass();

            // Create the new label and update the repository
            try {
                //default is view label
                if(_isRevision) {
                    newLabel = starTeamLabelFactory.CreateRevisionLabel(snapshot,_labelName, _description);
                }
                else {
                    newLabel = starTeamLabelFactory.CreateViewLabel(snapshot,_labelName, _description, _labelAsOfDate, _isBuildLabel);
                }
                newLabel.update();

                string sLabelType; 
                if (this._isRevision) {
                    sLabelType = "Revision";
                } else {
                    sLabelType = (this._isBuildLabel ? "View Build" : "View");
                }

                Log(Level.Info, "Created '{0}' label '{1}'", 
                    sLabelType, _labelName);

                return newLabel;
            } catch(Exception ex) {
                throw new BuildException(string.Format("Creating label '{0}' failed.", 
                    _labelName), Location, ex);
            }
        }
    }
}
www.java2v.com | Contact Us
Copyright 2009 - 12 Demo Source and Support. All rights reserved.
All other trademarks are property of their respective owners.