Survey
* Your assessment is very important for improving the workof artificial intelligence, which forms the content of this project
* Your assessment is very important for improving the workof artificial intelligence, which forms the content of this project
Tips & Tricks Tips and Tricks for CodeSmith 3.0 Rob Howard [email protected] CodeSmith Tools, LLC For More Information… • Learn more • www.codesmithtools.com • Download free 30 day trial • Contact Us • [email protected] • +1 972 407 0688 • CodeSmith & Telligent • Partnered together with a common goal: • “Build world-class software tools” Agenda • • • • • What is CodeSmith? Using CodeSmith 3.0 Working with Data & XML Advanced Tips & Tricks Licensing & Pricing What is Code Generation • Software creation • Can be fun and challenging • …but also repetitive and monotonous • Repetition & monotony leads to bugs • Code generation is not a new concept • With most tools you don’t control the output • Often viewed as a “Black Box” solution • Ex, data layer created (but it is not your code) • CodeSmith 3.0 • Not a “Black Box” solution • Template driven code generation (it is your code) • Use existing templates or write new ones The value of CodeSmith • The cost of creating software • Design, Development, Test, Release • Easily runs between $50 - $300/hour • CodeSmith • CodeSmith 3.0 Professional: $299 • Equivalent to 3-6 hours of development • Real value you can measure • Dramatically reduces project time & cost • Quickly pays for itself Your code. Your way. Faster! • CodeSmith • Version 2.6, released January 2004 • Version 3.0, released May 2005 • Version 3.1, released August 2005 • CodeSmith 3.0 includes • • • • CodeSmith Professional Studio (IDE) Visual Studio .NET integration Command line code generation engine Base set of common templates New in Version 3.0 • • • • • • • • Active Generation Templates Statement Completion, AKA Intellisense™ Deep XML support New merge strategies & preserve region Easier template debugging Template caching for faster execution Event driven template architecture Ability to auto-execute SQL scripts …and much, much more Customers include… …and many others Using CodeSmith 3.0 CodeSmith Professional Studio • Integrated Development Environment • Editing and Executing templates • Template Explorer • Professional Edition only • Features • • • • Database schema browser Template syntax highlighting Template, Output, and Compilation views Property editing CodeSmith Templates • Similar to ASP.NET page • CodeSmith Templates will be familiar • Event and <% %> code • Template contains • • • • Directives Template logic (VB & C# code) Output Text (your code, comments, etc.) Template events, methods, and properties • A CodeSmith template is • Document with .cst extension • Edit with CodeSmith Studio or text editor Statement Completion • CodeSmith 2.6 • Lacked Intellisense support • Required intimate knowledge of APIs • CodeSmith 3.0 • Full statement completion support • VB.NET and C# • Intellisense • Makes you more productive • Reduces development time My First Template Visual Studio Integration • Integrated with Visual Studio .NET • Automatically integrated during installation • “Visual Studio add-in” • Using CodeSmith within Visual Studio .NET • Tools -> Add-in Manager • Tools -> CodeSmith Explorer • Executing Templates in Visual Studio .NET • View templates in Template Explorer • Right-click to execute templates CodeSmith Add-in CodeSmith Explorer Visual Studio Integration Active & Passive Generation • Passive Generation • Use CodeSmith as “key stroke” saver • Render template and then use results • CodeSmith may or may not be used again • Active Generation (Recommended) • Use template as source code • Whenever build project run template • Ex, write single template to generate 100s of classes (or other files) Active Generation Templates • Enabled through Visual Studio Custom Tool • • • • “Active Generation Templates” Executed each time the input file changes Perfect for Active Generation Example: SampleProjects\CSharpCodeGeneratorSample • Execute Active Generation Templates • • • • • Right-click hashtable.xml in VS .NET Select ‘Run Custom Tool’ Renders multiple property sets for template Any time xml file is touched templates are regenerated Click on show all files to see hidden code files Bound to Custom Tool Generated Source File Generated Source Active Generation Template Working with Data & XML Creating Data Access Layer • Stored Procedures (SPROC) • Preferred data access technique • Provides abstraction API for data access • Create/Read/Update/Delete (CRUD) • Tedious to write (Equals more bugs) • Imagine manually creating for every table • StoredProcedures.cst Template • Generates CRUD layer for any table • Created in seconds! …for all tables Creating Data Access Layer Auto SQL Script Execution • Automatically update database • Generated SQL is automatically executed • Maintain entities in CodeSmith • Updating template to update schema • Ex, Telligent used CodeSmith for VSIP • 100% template driven database layer Script Execution Building Data Access APIs • Data Access Layer • APIs for working with data APIs, e.g. sprocs • Typically monotonous repetitive code • Time consuming to code by hand • Encourages Stored Procedures • Template generates typed wrapper • VB.NET and C# • Enforces best practices • Open connection late, close early • Try/Catch blocks Building Data Access APIs Building Data Access APIs • AllCommandWrappers.cst Template • Point to a database • CodeSmith outputs all occurrences • OutputDirectory • Default location for generated files • Configurable, e.g. “my project directory” • Generate entire data layer • Can exclude stored procedures Building Data Access APIs Database Documentation • DbDocumenter Templates (master.cst) • Set basic information and run batch file • Ex, database connection and title • Great demo of CodeSmith capabilities • Simple repetitive problem • Would take weeks to create manually • Demonstrates CodeSmith “best practices” • Additional ideas… • Modify templates to generate ASP.NET • Generate .CHM help files • Add execute capabilities, etc. Database Documentation Working with XML • New XmlProperty • Work with XML in a strongly typed manner • Using XML as metadata very easy • With an XSD • Strongly typed accessory to XML file • Read-only access • Without an XSD file • XmlDocument type returned XmlProperty Directive Advanced Tips & Tricks Debugging Templates • Set Debugger.Break() in code • Break-point in Template execution • .NET JIT Debugger window opens • From .NET JIT Debugger window • Select Debug Tool • EX, Visual Studio .NET 2003 • Step through template source • Reports error in template directly • Most tools allow debugging of the result Debugging Templates, cont • Compilation is similar to ASP.NET • Occasionally template is not enough • Need the ability to examine source • LinePragmas • Defined in <%@ CodeTemplate %> • Set to true or false • Default to true • Reports line number in template • False, reports line number in generated code Debugging Templates Template Events & Overrides • Initialization events • Called once when template is instantiated • OnInit • Called once when template is instantiated • All other events are raised on each use • ParseDefaultValue() • Allows for handling of type conversions • Called for every default value of a property • GetFileName() • Override the default output file name Template Events & Overrides • ‘Render’ events • Similar in concept to ASP.NET events • Called each time template instance is rendered • OnPreRender • Called before template rendering begins • Set up default state • Render • If overridden takes over rendering process • Example, if you want a ‘master’ template • OnPostRender • Called after template is executed • Contains string result of rendered template Template Events & Overrides Automated Build Process • Easily fit with your build environment • Constantly validate ability to build code • Example: NAnt, MSBuild • CodeSmith Command line tool • Build project from command line • CodeSmith used for Active Generation • Easily integrated into environment Command Line Tool • Console Application (cs.exe) • • • • • XML file identifying templates to run Mirror Visual Studio Custom Tool behavior Execute single template, or… Execute batches of templates Set properties via the Command Line • Example usage: • SampleProjects\ConsoleSamples • Use /batch:<file> cs.exe /batch:BatchModeSample.xml Batch Generation File Format • <defaultTemplate/> • Default template used to generate output • Can be overridden in <propertySet/> • <variables/> • Metadata used in property definitions • <defaultProperties/> • Define global properties • <propertySet/> • Serialized representation of template properties Batch Generation Merge Strategies • Enable Active Generation • Can’t always generate exactly what you need • Custom logic along with Active Generation • Example • SampleProjects\ConsoleSamples • PreserveRegionsMergeSample.cst Merge Strategies Licensing • CodeSmith 2.6 • Standard Edition was free • Professional Edition: $79 • CodeSmith 3.0 • Upgrade from 2.6 to 3.0 Professional: $49 • Standard Edition: $49 • Professional Edition: $299 • Support Options • Community Support codesmithtools.com • Premier / Incident support: $99 Conclusion • CodeSmith 3.0 • Most powerful code generation tool available • Reduces time spent writing trivial code • Be more productive • Template driven means it’s still your code • Saves you time and money • Coming soon: CodeSmith 3.1 • Minor bug fix, etc. release • Includes updated product documentation Learn more • www.codesmithtools.com • Download free 30 day trial Contact Us • [email protected] • +1 972 407 0688