Fixed highlightunread and areareplydirect

This commit is contained in:
Alexander S. Aganichev 2001-09-07 04:15:16 +00:00
parent 0a16f51eb0
commit 07ba5c6413
6 changed files with 258 additions and 168 deletions

View File

@ -12,6 +12,14 @@ ______________________________________________________________________
Notes for GoldED+ 1.1.5, /snapshot/ Notes for GoldED+ 1.1.5, /snapshot/
______________________________________________________________________ ______________________________________________________________________
- Fixed AreaReplyDirect operation when AreaReply is defined (Thanks to
Pavel Gulchouck for the patch).
- Fixed problem with incorrect updating of timesread field when
MSGLISTFIRST is YES.
! @pseudo creation stops at dot now as well.
- Added EditDeleteSOL action: delete text to the start of line. It - Added EditDeleteSOL action: delete text to the start of line. It
works the same way as EditDeleteEOL in terms of what we consider to works the same way as EditDeleteEOL in terms of what we consider to
be a line, since it deletes to the start of the line as it seen in be a line, since it deletes to the start of the line as it seen in

View File

@ -326,7 +326,7 @@ char* TokenXlat(int mode, char* input, GMsg* msg, GMsg* oldmsg, int __origarea)
continue; continue;
if(tokenxchg(dst, "@msgs", msgs)) if(tokenxchg(dst, "@msgs", msgs))
continue; continue;
if(tokenxchg(dst, "@cpseudo", *AA->Nickname() ? AA->Nickname() : strlword(strcpy(buf, AA->Username().name), " @"))) if(tokenxchg(dst, "@cpseudo", *AA->Nickname() ? AA->Nickname() : strlword(strcpy(buf, AA->Username().name), " @.")))
continue; continue;
if(tokenxchg(dst, "@version", __gver_ver__)) if(tokenxchg(dst, "@version", __gver_ver__))
continue; continue;

View File

@ -43,6 +43,7 @@ int reader_direction;
int reader_rcv_noise = false; int reader_rcv_noise = false;
gkey reader_keycode; gkey reader_keycode;
gkey reader_lastcode = 0; gkey reader_lastcode = 0;
bool reader_msglistfirst = false;
GMsgHeaderView *HeaderView; GMsgHeaderView *HeaderView;
GMsgBodyView *BodyView; GMsgBodyView *BodyView;
@ -185,8 +186,12 @@ void Reader() {
else { else {
AL.SetActiveAreaNo(startecho); AL.SetActiveAreaNo(startecho);
AA->RandomizeData(); AA->RandomizeData();
if(AA->Msglistfirst()) if(AA->Msglistfirst()) {
reader_msglistfirst = true;
kbput(KK_ReadMessageList); kbput(KK_ReadMessageList);
}
else
reader_msglistfirst = false;
} }
if(not reader_finished) { if(not reader_finished) {
@ -261,33 +266,35 @@ void Reader() {
HeaderView->Paint(); HeaderView->Paint();
if(AA->isreadmark or AA->isreadpm) { if(reader_msglistfirst == false) {
GTag& tag = AA->isreadpm ? AA->PMrk : AA->Mark; if(AA->isreadmark or AA->isreadpm) {
uint mtemp = tag.Find(msg->msgno); GTag& tag = AA->isreadpm ? AA->PMrk : AA->Mark;
sprintf(buf2, "%s [%s%s%s%s]", uint mtemp = tag.Find(msg->msgno);
LNG->ReadMarked, sprintf(buf2, "%s [%s%s%s%s]",
AA->Viewhidden() ? "H" : "", LNG->ReadMarked,
AA->Viewkludge() ? "K" : "", AA->Viewhidden() ? "H" : "",
AA->Twitmode() == TWIT_IGNORE ? "Ti" : AA->Twitmode() == TWIT_SKIP ? "Ts" : AA->Twitmode() == TWIT_BLANK ? "Tb" : AA->Twitmode() == TWIT_KILL ? "Tk" : "", AA->Viewkludge() ? "K" : "",
CFG->showdeleted ? "D" : "" AA->Twitmode() == TWIT_IGNORE ? "Ti" : AA->Twitmode() == TWIT_SKIP ? "Ts" : AA->Twitmode() == TWIT_BLANK ? "Tb" : AA->Twitmode() == TWIT_KILL ? "Tk" : "",
); CFG->showdeleted ? "D" : ""
sprintf(buf, buf2, );
mtemp, tag.Count(), tag.Count()-mtemp sprintf(buf, buf2,
); mtemp, tag.Count(), tag.Count()-mtemp
);
}
else {
sprintf(buf2, "%s [%s%s%s%s]",
LNG->ReadAll,
AA->Viewhidden() ? "H" : "",
AA->Viewkludge() ? "K" : "",
AA->Twitmode() == TWIT_IGNORE ? "Ti" : AA->Twitmode() == TWIT_SKIP ? "Ts" : AA->Twitmode() == TWIT_BLANK ? "Tb" : AA->Twitmode() == TWIT_KILL ? "Tk" : "",
CFG->showdeleted ? "D" : ""
);
sprintf(buf, buf2,
AA->lastread(), AA->Msgn.Count(), AA->Msgn.Count()-AA->lastread()
);
}
update_statusline(buf);
} }
else {
sprintf(buf2, "%s [%s%s%s%s]",
LNG->ReadAll,
AA->Viewhidden() ? "H" : "",
AA->Viewkludge() ? "K" : "",
AA->Twitmode() == TWIT_IGNORE ? "Ti" : AA->Twitmode() == TWIT_SKIP ? "Ts" : AA->Twitmode() == TWIT_BLANK ? "Tb" : AA->Twitmode() == TWIT_KILL ? "Tk" : "",
CFG->showdeleted ? "D" : ""
);
sprintf(buf, buf2,
AA->lastread(), AA->Msgn.Count(), AA->Msgn.Count()-AA->lastread()
);
}
update_statusline(buf);
reader_done = false; reader_done = false;
reader_keyok = false; reader_keyok = false;
@ -296,95 +303,100 @@ void Reader() {
AA->set_lastread(AA->Msgn.ToReln(msg->msgno)); AA->set_lastread(AA->Msgn.ToReln(msg->msgno));
AA->UpdateAreadata(); AA->UpdateAreadata();
// Determine if the message is of the "twit" type if(reader_msglistfirst == false) {
istwit = MsgIsTwit(msg, istwitto, istwitsubj);
if(istwit) // Determine if the message is of the "twit" type
HandleGEvent(EVTT_MSGISTWIT); istwit = MsgIsTwit(msg, istwitto, istwitsubj);
if((istwit == TWIT_SKIP) or (not CFG->showdeleted and msg->attr.del())) { if(istwit)
if(reader_direction == DIR_NEXT) { HandleGEvent(EVTT_MSGISTWIT);
if(AA->lastread() < AA->Msgn.Count()) {
if(gkbd.kbuf == NULL) { if((istwit == TWIT_SKIP) or (not CFG->showdeleted and msg->attr.del())) {
switch(reader_lastcode) { if(reader_direction == DIR_NEXT) {
case KK_ReadGotoReplies: if(AA->lastread() < AA->Msgn.Count()) {
case KK_ReadGotoReply1st: if(gkbd.kbuf == NULL) {
case KK_ReadGotoReplyNext: switch(reader_lastcode) {
if(MsgHasReplies(msg)) { case KK_ReadGotoReplies:
kbput(KK_ReadGotoReplies); case KK_ReadGotoReply1st:
} case KK_ReadGotoReplyNext:
else { if(MsgHasReplies(msg)) {
SayBibi(); kbput(KK_ReadGotoReplies);
kbput(KK_ReadGotoReplyPrev); }
} else {
break; SayBibi();
default: kbput(KK_ReadGotoReplyPrev);
kbput(KK_ReadGotoNextMsg); }
} break;
} default:
} kbput(KK_ReadGotoNextMsg);
}
else {
if(AA->lastread() > 1) {
if(gkbd.kbuf == NULL) {
if(reader_lastcode == KK_ReadGotoReplyPrev) {
if(AA->Msgn.ToReln(msg->link.to()))
kbput(KK_ReadGotoReplyPrev);
else {
SayBibi();
kbput(KK_ReadGotoReplies);
} }
} }
else }
kbput(KK_ReadGotoPrevMsg); }
else {
if(AA->lastread() > 1) {
if(gkbd.kbuf == NULL) {
if(reader_lastcode == KK_ReadGotoReplyPrev) {
if(AA->Msgn.ToReln(msg->link.to()))
kbput(KK_ReadGotoReplyPrev);
else {
SayBibi();
kbput(KK_ReadGotoReplies);
}
}
else
kbput(KK_ReadGotoPrevMsg);
}
} }
} }
} }
}
BodyView->Use(AA, msg, reader_topline); BodyView->Use(AA, msg, reader_topline);
if(istwit > TWIT_SHOW) { if(istwit > TWIT_SHOW) {
BodyView->window.clear(); BodyView->window.clear();
if(istwit == TWIT_SKIP) if(istwit == TWIT_SKIP)
BodyView->window.prints(1, 0, C_READW, LNG->SkippingTwit); BodyView->window.prints(1, 0, C_READW, LNG->SkippingTwit);
else if(istwit == TWIT_KILL) else if(istwit == TWIT_KILL)
BodyView->window.prints(1, 0, C_READW, LNG->KillingTwit); BodyView->window.prints(1, 0, C_READW, LNG->KillingTwit);
else {
BodyView->window.prints(1, 0, C_READW, LNG->HidingTwit);
}
}
else { else {
BodyView->window.prints(1, 0, C_READW, LNG->HidingTwit); BodyView->Paint();
}
if(reader_rcv_noise) {
if(CFG->beepyourmail == ALWAYS)
HandleGEvent(EVTT_MSGTOYOU);
else if(reader_rcv_noise > 1 and CFG->beepyourmail == true)
HandleGEvent(EVTT_MSGTOYOU);
reader_rcv_noise = false;
}
else {
if(msg->attr.fmu())
HandleGEvent(EVTT_MSGFROMYOU);
}
if(msg->attr.loc() and CFG->switches.get(beeplocalmsg))
HandleGEvent(EVTT_MSGISLOCAL);
if(AA->Msgn.Count() and CFG->switches.get(highlightunread) and (msg->orig_timesread == 0))
AA->UpdateTimesread(msg);
switch(istwit) {
case TWIT_KILL:
TwitDeleteMsg(msg);
continue;
case TWIT_SKIP:
reader_keycode = ReaderGetKey();
break;
default:
reader_keycode = ViewMessage(istwit);
} }
} }
else { else
BodyView->Paint(); reader_keycode = ReaderGetKey();
}
if(reader_rcv_noise) {
if(CFG->beepyourmail == ALWAYS)
HandleGEvent(EVTT_MSGTOYOU);
else if(reader_rcv_noise > 1 and CFG->beepyourmail == true)
HandleGEvent(EVTT_MSGTOYOU);
reader_rcv_noise = false;
}
else {
if(msg->attr.fmu())
HandleGEvent(EVTT_MSGFROMYOU);
}
if(msg->attr.loc() and CFG->switches.get(beeplocalmsg))
HandleGEvent(EVTT_MSGISLOCAL);
if(AA->Msgn.Count() and CFG->switches.get(highlightunread) and (msg->orig_timesread == 0))
AA->UpdateTimesread(msg);
switch(istwit) {
case TWIT_KILL:
TwitDeleteMsg(msg);
continue;
case TWIT_SKIP:
reader_keycode = ReaderGetKey();
break;
default:
reader_keycode = ViewMessage(istwit);
}
reader_topline = BodyView->UpperLine(); reader_topline = BodyView->UpperLine();
@ -572,6 +584,7 @@ void Reader() {
case KK_ReadMessageList: case KK_ReadMessageList:
MessageBrowse(); MessageBrowse();
reader_msglistfirst = false;
break; break;
case KK_ReadThreadtree: case KK_ReadThreadtree:
@ -580,7 +593,7 @@ void Reader() {
case KK_ReadDosShell: case KK_ReadDosShell:
DosShell(); DosShell();
reader_keyok = YES; reader_keyok = true;
break; break;
case KK_ReadFindAll: case KK_ReadFindAll:
@ -914,42 +927,44 @@ int LoadMessage(GMsg* msg, int margin) {
msg->attr.tou1(); msg->attr.tou1();
} }
if(msg->attr.tou()) { if(reader_msglistfirst == false) {
reader_rcv_noise = 1; if(msg->attr.tou()) {
if(not msg->attr.rcv()) { // Have we seen it? reader_rcv_noise = 1;
time_t a = time(NULL); if(not msg->attr.rcv()) { // Have we seen it?
struct tm *tp = gmtime(&a); time_t a = time(NULL);
tp->tm_isdst = -1; struct tm *tp = gmtime(&a);
time_t b = mktime(tp); tp->tm_isdst = -1;
msg->received = a + a - b; // Get current date time_t b = mktime(tp);
msg->attr.rcv1(); // Mark as received msg->received = a + a - b; // Get current date
reader_rcv_noise++; msg->attr.rcv1(); // Mark as received
reader_rcv_noise++;
}
else if(not CFG->switches.get(rcvdisablescfm))
reader_rcv_noise++;
} }
else if(not CFG->switches.get(rcvdisablescfm))
reader_rcv_noise++; // Touch the msg if it's the first time received
if(reader_rcv_noise > 1)
msg->attr.upd1(); // Tell SaveHdr to "touch" the time stamp of the *.MSG file
// Update the "Times Read" field
msg->orig_timesread = msg->timesread++;
if(reader_rcv_noise > 1) {
GMsg* tmsg = (GMsg*) throw_calloc(1, sizeof(GMsg));
AA->LoadHdr(tmsg, msg->msgno, false);
tmsg->attr = msg->attr;
tmsg->orig_timesread = msg->orig_timesread;
tmsg->received = msg->received;
AA->SaveHdr(GMSG_UPDATE, tmsg);
throw_free(tmsg);
}
msg->attr.upd0();
if((reader_rcv_noise > 1) and AA->isnet() and (msg->attr.cfm() or msg->attr.rrq()))
reader_gen_confirm = true;
} }
// Touch the msg if it's the first time received
if(reader_rcv_noise > 1)
msg->attr.upd1(); // Tell SaveHdr to "touch" the time stamp of the *.MSG file
// Update the "Times Read" field
msg->orig_timesread = msg->timesread++;
if(reader_rcv_noise > 1) {
GMsg* tmsg = (GMsg*) throw_calloc(1, sizeof(GMsg));
AA->LoadHdr(tmsg, msg->msgno, false);
tmsg->attr = msg->attr;
tmsg->orig_timesread = msg->orig_timesread;
tmsg->received = msg->received;
AA->SaveHdr(GMSG_UPDATE, tmsg);
throw_free(tmsg);
}
msg->attr.upd0();
if((reader_rcv_noise > 1) and AA->isnet() and (msg->attr.cfm() or msg->attr.rrq()))
reader_gen_confirm = true;
} }
} }
else { else {

View File

@ -36,6 +36,7 @@
// Global data from GEREAD // Global data from GEREAD
extern GMsg* reader_msg; extern GMsg* reader_msg;
extern bool reader_msglistfirst;
// ------------------------------------------------------------------ // ------------------------------------------------------------------
@ -485,8 +486,10 @@ void NewArea(bool jumpnext) {
OrigArea = CurrArea; OrigArea = CurrArea;
strcpy(stecho, AA->echoid()); strcpy(stecho, AA->echoid());
AA->RandomizeData(); AA->RandomizeData();
if(AA->Msglistfirst()) if(AA->Msglistfirst()) {
kbput(KK_ReadMessageList); kbput(KK_ReadMessageList);
reader_msglistfirst = true;
}
} }
} }

View File

@ -273,13 +273,13 @@ int TemplateToText(int mode, GMsg* msg, GMsg* oldmsg, const char* tpl, int origa
// build @tpseudo // build @tpseudo
if(is_user(msg->to)) if(is_user(msg->to))
strcpy(msg->pseudoto, *AA->Nickname() ? AA->Nickname() : strlword(msg->to, " @")); strcpy(msg->pseudoto, *AA->Nickname() ? AA->Nickname() : strlword(msg->to, " @."));
else else
*(msg->pseudoto) = NUL; *(msg->pseudoto) = NUL;
// build @fpseudo // build @fpseudo
if(is_user(msg->By())) if(is_user(msg->By()))
strcpy(msg->pseudofrom, *AA->Nickname() ? AA->Nickname() : strlword(msg->By(), " @")); strcpy(msg->pseudofrom, *AA->Nickname() ? AA->Nickname() : strlword(msg->By(), " @."));
else else
*(msg->pseudofrom) = NUL; *(msg->pseudofrom) = NUL;
@ -394,6 +394,8 @@ int TemplateToText(int mode, GMsg* msg, GMsg* oldmsg, const char* tpl, int origa
goto loop_next; goto loop_next;
if(AL.AreaIdToPtr(origarea)->Areareplydirect() and oldmsg->areakludgeid and strieql(oldmsg->areakludgeid, AA->echoid())) if(AL.AreaIdToPtr(origarea)->Areareplydirect() and oldmsg->areakludgeid and strieql(oldmsg->areakludgeid, AA->echoid()))
goto loop_next; goto loop_next;
if(AL.AreaIdToPtr(origarea)->Areareplydirect() and strieql(AL.AreaIdToPtr(origarea)->Areareplyto(), AA->echoid()))
goto loop_next;
if(strieql(oldmsg->fwdarea, AA->echoid())) if(strieql(oldmsg->fwdarea, AA->echoid()))
goto loop_next; goto loop_next;
token = end_token; token = end_token;
@ -962,16 +964,68 @@ void ConfirmMsg() {
bool _allow_pick = true; bool _allow_pick = true;
void OtherAreaReplyMsg() {
if(AA->Msgn.Count()) {
int destarea = CurrArea;
if(CurrArea == OrigArea) {
if(*AA->Areareplyto()) {
int a = AL.AreaEchoToNo(AA->Areareplyto());
if(a != -1)
destarea = AL.AreaNoToId(a);
}
reader_topline = 0;
AA->attr().hex0();
const char* destinationecho = *reader_msg->fwdarea ? reader_msg->fwdarea : reader_msg->areakludgeid;
if(destinationecho and *destinationecho) {
for(uint n=0; n<AL.size(); n++) {
if(strieql(AL[n]->echoid(), destinationecho)) {
destarea = AL[n]->areaid();
break;
}
}
}
if(_allow_pick or not AA->Areareplydirect())
destarea = AreaPick(LNG->ReplyArea, 6, &destarea);
}
if(destarea != -1) {
int adat_viewhidden = AA->adat->viewhidden;
int adat_viewkludge = AA->adat->viewkludge;
int adat_viewquote = AA->adat->viewquote;
AL.SetActiveAreaId(destarea);
if(CurrArea != OrigArea) {
AA->Open();
if(CurrArea != OrigArea) {
AA->adat->viewhidden = adat_viewhidden;
AA->adat->viewkludge = adat_viewkludge;
AA->adat->viewquote = adat_viewquote;
}
}
ReplyMsg();
if(CurrArea != OrigArea) {
AA->Close();
AL.SetActiveAreaId(OrigArea);
}
}
}
}
// ------------------------------------------------------------------
void ReplyMsg() { void ReplyMsg() {
if(CurrArea == OrigArea) { if(CurrArea == OrigArea) {
if(AA->Areareplydirect() and reader_msg->areakludgeid) { const char *destarea = AA->Areareplyto();
int a = AL.AreaEchoToNo(reader_msg->areakludgeid); if (!*destarea)
destarea = reader_msg->areakludgeid;
if(AA->Areareplydirect() and destarea) {
int a = AL.AreaEchoToNo(destarea);
if(a != -1) { if(a != -1) {
CurrArea = AL.AreaNoToId(a); CurrArea = AL.AreaNoToId(a);
if(CurrArea != OrigArea) { if(CurrArea != OrigArea) {
_allow_pick = false; _allow_pick = false;
OtherAreaQuoteMsg(); OtherAreaReplyMsg();
_allow_pick = true; _allow_pick = true;
return; return;
} }
@ -997,8 +1051,12 @@ void ReplyMsg() {
void QuoteMsg(bool ignore_replyto) { void QuoteMsg(bool ignore_replyto) {
if(CurrArea == OrigArea) { if(CurrArea == OrigArea) {
if(AA->Areareplydirect() and reader_msg->areakludgeid) { const char *destarea = AA->Areareplyto();
int a = AL.AreaEchoToNo(reader_msg->areakludgeid); if (!*destarea)
destarea = reader_msg->areakludgeid;
if(AA->Areareplydirect() and destarea) {
int a = AL.AreaEchoToNo(destarea);
if(a != -1) { if(a != -1) {
CurrArea = AL.AreaNoToId(a); CurrArea = AL.AreaNoToId(a);
if(CurrArea != OrigArea) { if(CurrArea != OrigArea) {
@ -1029,8 +1087,12 @@ void QuoteMsg(bool ignore_replyto) {
void CommentMsg() { void CommentMsg() {
if(CurrArea == OrigArea) { if(CurrArea == OrigArea) {
if(AA->Areareplydirect() and reader_msg->areakludgeid) { const char *destarea = AA->Areareplyto();
int a = AL.AreaEchoToNo(reader_msg->areakludgeid); if (!*destarea)
destarea = reader_msg->areakludgeid;
if(AA->Areareplydirect() && destarea) {
int a = AL.AreaEchoToNo(destarea);
if(a != -1) { if(a != -1) {
CurrArea = AL.AreaNoToId(a); CurrArea = AL.AreaNoToId(a);
if(CurrArea != OrigArea) { if(CurrArea != OrigArea) {
@ -1112,24 +1174,26 @@ void OtherAreaCommentMsg() {
if(AA->Msgn.Count()) { if(AA->Msgn.Count()) {
int destarea = CurrArea; int destarea = CurrArea;
if(*AA->Areareplyto()) { if(CurrArea == OrigArea) {
int a = AL.AreaEchoToNo(AA->Areareplyto()); if(*AA->Areareplyto()) {
if(a != -1) int a = AL.AreaEchoToNo(AA->Areareplyto());
destarea = AL.AreaNoToId(a); if(a != -1)
} destarea = AL.AreaNoToId(a);
reader_topline = 0; }
AA->attr().hex0(); reader_topline = 0;
const char* destinationecho = *reader_msg->fwdarea ? reader_msg->fwdarea : reader_msg->areakludgeid; AA->attr().hex0();
if(destinationecho and *destinationecho) { const char* destinationecho = *reader_msg->fwdarea ? reader_msg->fwdarea : reader_msg->areakludgeid;
for(uint n=0; n<AL.size(); n++) { if(destinationecho and *destinationecho) {
if(strieql(AL[n]->echoid(), destinationecho)) { for(uint n=0; n<AL.size(); n++) {
destarea = AL[n]->areaid(); if(strieql(AL[n]->echoid(), destinationecho)) {
break; destarea = AL[n]->areaid();
break;
}
} }
} }
if(_allow_pick or not AA->Areareplydirect())
destarea = AreaPick(LNG->ReplyArea, 6, &destarea);
} }
if(_allow_pick or not AA->Areareplydirect())
destarea = AreaPick(LNG->ReplyArea, 6, &destarea);
if(destarea != -1) { if(destarea != -1) {
int adat_viewhidden = AA->adat->viewhidden; int adat_viewhidden = AA->adat->viewhidden;
int adat_viewkludge = AA->adat->viewkludge; int adat_viewkludge = AA->adat->viewkludge;

View File

@ -868,9 +868,9 @@ bool guserbase::lookup_addressbook(GMsg* msg, char* name, char* aka, bool browse
void guserbase::build_pseudo(GMsg* msg, char* name, char* aka, bool direction) { void guserbase::build_pseudo(GMsg* msg, char* name, char* aka, bool direction) {
if(*msg->iaddr and isuucp(name)) if(*msg->iaddr and isuucp(name))
strcpy(direction ? msg->pseudoto : msg->pseudofrom, strlword(msg->iaddr, " @")); strcpy(direction ? msg->pseudoto : msg->pseudofrom, strlword(msg->iaddr, " @."));
else else
strcpy(direction ? msg->pseudoto : msg->pseudofrom, strlword(name, " @")); strcpy(direction ? msg->pseudoto : msg->pseudofrom, strlword(name, " @."));
if(find_entry(name, true) and not entry.is_deleted) { if(find_entry(name, true) and not entry.is_deleted) {