Skip white space - to delete strategically

This commit is contained in:
Arran Ubels 2023-02-15 16:27:43 +11:00
parent 268a690081
commit bf3a5b3040
No known key found for this signature in database
GPG Key ID: 135EDC7B21D17F48

View File

@ -383,6 +383,9 @@ iterRunes:
} }
case ' ': case ' ':
for i+1 < len(datestr) && datestr[i+1] == ' ' {
i++
}
// 18 January 2018 // 18 January 2018
// 8 January 2018 // 8 January 2018
// 8 jan 2018 // 8 jan 2018
@ -446,6 +449,9 @@ iterRunes:
p.stateDate = dateYearDashDashOffset p.stateDate = dateYearDashDashOffset
p.setDay() p.setDay()
case ' ': case ' ':
for i+1 < len(datestr) && datestr[i+1] == ' ' {
i++
}
p.daylen = i - p.dayi p.daylen = i - p.dayi
p.stateDate = dateYearDashDashWs p.stateDate = dateYearDashDashWs
p.stateTime = timeStart p.stateTime = timeStart
@ -506,6 +512,9 @@ iterRunes:
// 29-Jun-2016 dd-month(alpha)-yyyy // 29-Jun-2016 dd-month(alpha)-yyyy
switch r { switch r {
case ' ': case ' ':
for i+1 < len(datestr) && datestr[i+1] == ' ' {
i++
}
// we need to find if this was 4 digits, aka year // we need to find if this was 4 digits, aka year
// or 2 digits which makes it ambiguous year/day // or 2 digits which makes it ambiguous year/day
length := i - (p.moi + p.molen + 1) length := i - (p.moi + p.molen + 1)
@ -538,7 +547,12 @@ iterRunes:
// I honestly don't know if this format ever shows up as yyyy/ // I honestly don't know if this format ever shows up as yyyy/
switch r { switch r {
case ' ', ':': case ' ':
for i+1 < len(datestr) && datestr[i+1] == ' ' {
i++
}
fallthrough
case ':':
p.stateTime = timeStart p.stateTime = timeStart
if p.daylen == 0 { if p.daylen == 0 {
p.daylen = i - p.dayi p.daylen = i - p.dayi
@ -566,7 +580,12 @@ iterRunes:
} }
// We aren't breaking because we are going to re-use this case // We aren't breaking because we are going to re-use this case
// to find where the date starts, and possible time begins // to find where the date starts, and possible time begins
case ' ', ':': case ' ':
for i+1 < len(datestr) && datestr[i+1] == ' ' {
i++
}
fallthrough
case ':':
p.stateTime = timeStart p.stateTime = timeStart
if p.yearlen == 0 { if p.yearlen == 0 {
p.yearlen = i - p.yeari p.yearlen = i - p.yeari
@ -604,6 +623,9 @@ iterRunes:
// Note no break, we are going to pass by and re-enter this dateDigitSlash // Note no break, we are going to pass by and re-enter this dateDigitSlash
// and look for ending (space) or not (just date) // and look for ending (space) or not (just date)
case ' ': case ' ':
for i+1 < len(datestr) && datestr[i+1] == ' ' {
i++
}
p.stateTime = timeStart p.stateTime = timeStart
if p.yearlen == 0 { if p.yearlen == 0 {
p.yearlen = i - p.yeari p.yearlen = i - p.yeari
@ -625,6 +647,9 @@ iterRunes:
switch r { switch r {
case ' ': case ' ':
for i+1 < len(datestr) && datestr[i+1] == ' ' {
i++
}
p.stateTime = timeStart p.stateTime = timeStart
if p.yearlen == 0 { if p.yearlen == 0 {
p.yearlen = i - p.yeari p.yearlen = i - p.yeari
@ -662,6 +687,9 @@ iterRunes:
// 12 Feb 2006, 19:17:22 // 12 Feb 2006, 19:17:22
switch r { switch r {
case ' ': case ' ':
for i+1 < len(datestr) && datestr[i+1] == ' ' {
i++
}
p.yeari = i + 1 p.yeari = i + 1
//p.yearlen = 4 //p.yearlen = 4
p.dayi = 0 p.dayi = 0
@ -696,6 +724,9 @@ iterRunes:
i++ i++
break iterRunes break iterRunes
case ' ': case ' ':
for i+1 < len(datestr) && datestr[i+1] == ' ' {
i++
}
p.yearlen = i - p.yeari p.yearlen = i - p.yeari
p.setYear() p.setYear()
break iterRunes break iterRunes
@ -710,6 +741,9 @@ iterRunes:
// weekday %Y年%m月%e日 %A %I:%M %p // weekday %Y年%m月%e日 %A %I:%M %p
// 2013年07月18日 星期四 10:27 上午 // 2013年07月18日 星期四 10:27 上午
if r == ' ' { if r == ' ' {
for i+1 < len(datestr) && datestr[i+1] == ' ' {
i++
}
p.stateDate = dateDigitChineseYearWs p.stateDate = dateDigitChineseYearWs
break break
} }
@ -770,6 +804,9 @@ iterRunes:
case r == ' ': case r == ' ':
// X // X
// April 8, 2009 // April 8, 2009
for i+1 < len(datestr) && datestr[i+1] == ' ' {
i++
}
if i > 3 { if i > 3 {
// Check to see if the alpha is name of month? or Day? // Check to see if the alpha is name of month? or Day?
month := strings.ToLower(datestr[0:i]) month := strings.ToLower(datestr[0:i])
@ -877,6 +914,9 @@ iterRunes:
p.setDay() p.setDay()
p.stateDate = dateAlphaWsDigitMore p.stateDate = dateAlphaWsDigitMore
} else if r == ' ' { } else if r == ' ' {
for i+1 < len(datestr) && datestr[i+1] == ' ' {
i++
}
p.daylen = i - p.dayi p.daylen = i - p.dayi
p.setDay() p.setDay()
p.yeari = i + 1 p.yeari = i + 1
@ -900,6 +940,9 @@ iterRunes:
p.yeari = 0 p.yeari = 0
break iterRunes break iterRunes
} else if r == ' ' { } else if r == ' ' {
for i+1 < len(datestr) && datestr[i+1] == ' ' {
i++
}
// must be year format, not 15:04 // must be year format, not 15:04
p.yearlen = i - p.yeari p.yearlen = i - p.yeari
p.setYear() p.setYear()
@ -913,6 +956,9 @@ iterRunes:
// oct 1, 1970 // oct 1, 1970
// oct 7, '70 // oct 7, '70
if r == ' ' { if r == ' ' {
for i+1 < len(datestr) && datestr[i+1] == ' ' {
i++
}
p.yeari = i + 1 p.yeari = i + 1
p.stateDate = dateAlphaWsDigitMoreWs p.stateDate = dateAlphaWsDigitMoreWs
} }
@ -925,7 +971,12 @@ iterRunes:
switch r { switch r {
case '\'': case '\'':
p.yeari = i + 1 p.yeari = i + 1
case ' ', ',': case ' ':
for i+1 < len(datestr) && datestr[i+1] == ' ' {
i++
}
fallthrough
case ',':
// x // x
// May 8, 2009 5:57:51 PM // May 8, 2009 5:57:51 PM
// x // x
@ -941,7 +992,12 @@ iterRunes:
// April 8, 2009 // April 8, 2009
// April 8 2009 // April 8 2009
switch r { switch r {
case ' ', ',': case ' ':
for i+1 < len(datestr) && datestr[i+1] == ' ' {
i++
}
fallthrough
case ',':
// x // x
// June 8, 2009 // June 8, 2009
// x // x
@ -973,6 +1029,9 @@ iterRunes:
i++ i++
break iterRunes break iterRunes
case ' ': case ' ':
for i+1 < len(datestr) && datestr[i+1] == ' ' {
i++
}
p.yearlen = i - p.yeari p.yearlen = i - p.yeari
p.setYear() p.setYear()
p.stateTime = timeStart p.stateTime = timeStart
@ -1027,6 +1086,9 @@ iterRunes:
} }
case r == ' ': case r == ' ':
for i+1 < len(datestr) && datestr[i+1] == ' ' {
i++
}
// x // x
// January 02 2006, 15:04:05 // January 02 2006, 15:04:05
p.daylen = i - p.dayi p.daylen = i - p.dayi
@ -1050,6 +1112,9 @@ iterRunes:
// oct. 7, '70 // oct. 7, '70
switch { switch {
case r == ' ': case r == ' ':
for i+1 < len(datestr) && datestr[i+1] == ' ' {
i++
}
// continue // continue
case unicode.IsDigit(r): case unicode.IsDigit(r):
p.stateDate = dateAlphaWsDigit p.stateDate = dateAlphaWsDigit
@ -1066,7 +1131,12 @@ iterRunes:
p.dayi = i p.dayi = i
} }
switch r { switch r {
case ' ', '-': case ' ':
for i+1 < len(datestr) && datestr[i+1] == ' ' {
i++
}
fallthrough
case '-':
if p.moi == 0 { if p.moi == 0 {
p.moi = i + 1 p.moi = i + 1
p.daylen = i - p.dayi p.daylen = i - p.dayi
@ -1088,7 +1158,12 @@ iterRunes:
// Tue, 11 Jul 2017 16:28:13 +0200 (CEST) // Tue, 11 Jul 2017 16:28:13 +0200 (CEST)
// Mon, 02-Jan-06 15:04:05 MST // Mon, 02-Jan-06 15:04:05 MST
switch r { switch r {
case ' ', '-': case ' ':
for i+1 < len(datestr) && datestr[i+1] == ' ' {
i++
}
fallthrough
case '-':
if p.dayi == 0 { if p.dayi == 0 {
p.dayi = i + 1 p.dayi = i + 1
} else if p.moi == 0 { } else if p.moi == 0 {
@ -1216,6 +1291,9 @@ iterRunes:
// x // x
// September 17, 2012 at 5:00pm UTC-05 // September 17, 2012 at 5:00pm UTC-05
i++ // skip ' i++ // skip '
for i+1 < len(datestr) && datestr[i+1] == ' ' {
i++
}
p.houri = 0 // reset hour p.houri = 0 // reset hour
} }
} else { } else {
@ -1240,6 +1318,9 @@ iterRunes:
p.set(i, "PM") p.set(i, "PM")
} }
case ' ': case ' ':
for i+1 < len(datestr) && datestr[i+1] == ' ' {
i++
}
p.coalesceTime(i) p.coalesceTime(i)
p.stateTime = timeWs p.stateTime = timeWs
case ':': case ':':
@ -1337,6 +1418,9 @@ iterRunes:
p.stateTime = timeWsAlphaZoneOffset p.stateTime = timeWsAlphaZoneOffset
p.offseti = i p.offseti = i
case ' ': case ' ':
for i+1 < len(datestr) && datestr[i+1] == ' ' {
i++
}
// 17:57:51 MST 2009 // 17:57:51 MST 2009
// 17:57:51 MST // 17:57:51 MST
p.tzlen = i - p.tzi p.tzlen = i - p.tzi
@ -1361,6 +1445,9 @@ iterRunes:
// 15:44:11 UTC+0100 2015 // 15:44:11 UTC+0100 2015
switch r { switch r {
case ' ': case ' ':
for i+1 < len(datestr) && datestr[i+1] == ' ' {
i++
}
p.set(p.offseti, "-0700") p.set(p.offseti, "-0700")
if p.yeari == 0 { if p.yeari == 0 {
p.yeari = i + 1 p.yeari = i + 1
@ -1423,6 +1510,9 @@ iterRunes:
case ':': case ':':
p.stateTime = timeWsOffsetColon p.stateTime = timeWsOffsetColon
case ' ': case ' ':
for i+1 < len(datestr) && datestr[i+1] == ' ' {
i++
}
p.set(p.offseti, "-0700") p.set(p.offseti, "-0700")
p.yeari = i + 1 p.yeari = i + 1
p.stateTime = timeWsOffsetWs p.stateTime = timeWsOffsetWs
@ -1503,6 +1593,9 @@ iterRunes:
// 06:20:00.000 UTC // 06:20:00.000 UTC
switch r { switch r {
case ' ': case ' ':
for i+1 < len(datestr) && datestr[i+1] == ' ' {
i++
}
p.mslen = i - p.msi p.mslen = i - p.msi
p.stateTime = timePeriodWs p.stateTime = timePeriodWs
case '+', '-': case '+', '-':
@ -1533,6 +1626,9 @@ iterRunes:
// 13:31:51.999 -07:00 MST // 13:31:51.999 -07:00 MST
switch r { switch r {
case ' ': case ' ':
for i+1 < len(datestr) && datestr[i+1] == ' ' {
i++
}
p.set(p.offseti, "-07:00") p.set(p.offseti, "-07:00")
p.stateTime = timePeriodOffsetColonWs p.stateTime = timePeriodOffsetColonWs
p.tzi = i + 1 p.tzi = i + 1
@ -1586,6 +1682,9 @@ iterRunes:
case ':': case ':':
p.stateTime = timePeriodWsOffsetColon p.stateTime = timePeriodWsOffsetColon
case ' ': case ' ':
for i+1 < len(datestr) && datestr[i+1] == ' ' {
i++
}
p.set(p.offseti, "-0700") p.set(p.offseti, "-0700")
case '+', '-': case '+', '-':
// This really doesn't seem valid, but for some reason when round-tripping a go date // This really doesn't seem valid, but for some reason when round-tripping a go date
@ -1615,6 +1714,9 @@ iterRunes:
// 13:31:51.999 -07:00 MST // 13:31:51.999 -07:00 MST
switch r { switch r {
case ' ': case ' ':
for i+1 < len(datestr) && datestr[i+1] == ' ' {
i++
}
p.set(p.offseti, "-07:00") p.set(p.offseti, "-07:00")
default: default:
if unicode.IsLetter(r) { if unicode.IsLetter(r) {