function buildCal(m, y, cM, cH, cDW, cD, brdr){
var mn=['January','February','March','April','May','June','July','August','September','October','November','December'];
var dim=[31,0,31,30,31,30,31,31,30,31,30,31];

var oD = new Date(y, m-1, 1); //DD replaced line to fix date bug when current day is 31st
oD.od=oD.getDay()+1; //DD replaced line to fix date bug when current day is 31st

var todaydate=new Date()
var curmonth=todaydate.getMonth()+1 //get current month (1-12)
var curyear=todaydate.getFullYear() //get current year
var scanfortoday=(y==todaydate.getFullYear() && m==todaydate.getMonth()+1)? todaydate.getDate() : 0 //DD added

dim[1]=(((oD.getFullYear()%100!=0)&&(oD.getFullYear()%4==0))||(oD.getFullYear()%400==0))?29:28;

var t='<div class="'+cM+'"><table class="'+cM+'" cols="7" cellpadding="0" border="'+brdr+'" cellspacing="0"><tr align="center">';
t+='<td colspan="7" align="center" class="'+cH+'">'+mn[m-1]+' - '+y+'</td></tr><tr align="center">';
for (s=0;s<7;s++) {t+='<td class="'+cDW+'">'+"SMTWTFS".substr(s,1)+'</td>'}
t+='</tr><tr align="center">';
for (i=1;i<=42;i++){
var x=((i-oD.od>=0)&&(i-oD.od<dim[m-1]))? i-oD.od+1 : '&nbsp;';
// alert(x);
cDclass = cD;
if ((m<curmonth && y==curyear && x!='&nbsp;') || (m==curmonth && x<todaydate.getDate() && x!='&nbsp;')) {cDclass="pastdays"}
else {
var n;
for (n in holiday) {
if (holiday[n]==x) {cDclass='holiday'}
}
for (n in blocked) {
if (blocked[n]==x) {cDclass='blocked'}
}
for (n in arrival) {
if (arrival[n]==x) {cDclass='arrival'}
}
for (n in departure) {
if (departure[n]==x) {cDclass='departure'}
}
}
if (x==scanfortoday) {x='<span id="today">'+x+'</span>'}
t+='<td class="'+cDclass+'">'+x+'</td>';
if(((i)%7==0)&&(i<36)) {t+='</tr><tr align="center">'}
}
return t+='</tr></table></div>';
}

