673 lines
19 KiB
Text
673 lines
19 KiB
Text
## 05_pantomime1.2.dpatch by Sergey Golovin <svgol@mail.ru>
|
|
##
|
|
## DP: Convert to Pantomime 1.2.
|
|
|
|
@DPATCH@
|
|
diff -urNad lusernet.app-0.4.2~/ChangeLog ChangeLog
|
|
--- lusernet.app-0.4.2~/ChangeLog 1970-01-01 02:00:00.000000000 +0200
|
|
+++ ChangeLog 2006-09-27 00:13:21.000000000 +0300
|
|
@@ -0,0 +1,41 @@
|
|
+2006-09-19 Sergey V. Golovin <svgol@mail.ru>
|
|
+
|
|
+ * main.m ([AppDelegate -changeEncoding:]): post
|
|
+ DefaultEncodingChangedNotification when done
|
|
+
|
|
+ * main.m: new notification DefaultEncodingChangedNotification
|
|
+
|
|
+ * ComposeWindowController.m: "DefaultEncoding" now influences all
|
|
+ messages that going to be posted (Yavor Doganov <yavor@doganov.org>)
|
|
+
|
|
+ * NNTPSourceGUI.m ([NNTPSourcePropertiesController
|
|
+ -initWithNNTPSource:]): the NNTPSourcePropertiesController is
|
|
+ responsible for releasing its window ([win release] removed from
|
|
+ end of -initWithNNTPSource:)
|
|
+
|
|
+ * MessageViewController.m ([MessageViewController -getData]):
|
|
+ - The "DefaultEncoding" should influence only such messages that
|
|
+ have no the content type header
|
|
+ - All normal messages are displayed with their charsets
|
|
+
|
|
+ * MessageViewController.m ([MessageViewController -encodingChanged:]): added
|
|
+ ([MessageViewController -initWithMsgDB:textView:scrollView:]): now it
|
|
+ waits for DefaultEncodingChangedNotification to redisplay
|
|
+ immediately a message if it is needed.
|
|
+
|
|
+2006-09-04 Sergey Golovin <svgol@mail.ru>
|
|
+
|
|
+ * Pref_MessageViewing.m ([Pref_MessageViewing -willShow]): added
|
|
+ a pop-up button for charset selection
|
|
+ ([Pref_MessageViewing -changeEncoding:]): added
|
|
+
|
|
+2006-09-02 Sergey Golovin <svgol@mail.ru>
|
|
+
|
|
+ * MessageViewController.m ([MessageViewController -getData]):
|
|
+ - added from user defaults a charset header when a raw message has
|
|
+ no one
|
|
+ - added from user defaults a content type header when a raw
|
|
+ message has no one
|
|
+
|
|
+ * synchronized with Pantomime 1.2
|
|
+
|
|
diff -urNad lusernet.app-0.4.2~/ComposeWindowController.h ComposeWindowController.h
|
|
--- lusernet.app-0.4.2~/ComposeWindowController.h 2004-03-03 01:58:37.000000000 +0200
|
|
+++ ComposeWindowController.h 2006-09-27 00:13:21.000000000 +0300
|
|
@@ -6,7 +6,7 @@
|
|
#define ComposeWindowController_h
|
|
|
|
@class NSString,NSDictionary;
|
|
-@class Message;
|
|
+@class CWMessage;
|
|
@class NSTextView,NSTextField,NSButton;
|
|
|
|
@interface ComposeWindowController : NSWindowController
|
|
@@ -25,7 +25,7 @@
|
|
|
|
- initWithHeaders: (NSDictionary *)headers quoteContent: (NSString *)content;
|
|
- initWithHeaders: (NSDictionary *)headers;
|
|
-- initWithFollowupToMessage: (Message *)msg;
|
|
+- initWithFollowupToMessage: (CWMessage *)msg;
|
|
|
|
@end
|
|
|
|
diff -urNad lusernet.app-0.4.2~/ComposeWindowController.m ComposeWindowController.m
|
|
--- lusernet.app-0.4.2~/ComposeWindowController.m 2004-03-03 01:58:37.000000000 +0200
|
|
+++ ComposeWindowController.m 2006-09-27 00:13:21.000000000 +0300
|
|
@@ -13,6 +13,7 @@
|
|
#include <AppKit/NSTextContainer.h>
|
|
#include <AppKit/NSTextField.h>
|
|
#include <AppKit/NSButton.h>
|
|
+#include <AppKit/NSGraphics.h>
|
|
#include <GNUstepGUI/GSVbox.h>
|
|
#include <GNUstepGUI/GSHbox.h>
|
|
|
|
@@ -21,11 +21,12 @@
|
|
#include "main.h"
|
|
#include "KeyWindow.h"
|
|
#include "Pref_Posting.h"
|
|
+#include "Pref_MessageViewing.h"
|
|
|
|
-#include <Pantomime/Constants.h>
|
|
-#include <Pantomime/Message.h>
|
|
-#include <Pantomime/MimeUtility.h>
|
|
-#include <Pantomime/InternetAddress.h>
|
|
+#include <Pantomime/CWConstants.h>
|
|
+#include <Pantomime/CWMessage.h>
|
|
+#include <Pantomime/CWMIMEUtility.h>
|
|
+#include <Pantomime/CWInternetAddress.h>
|
|
|
|
|
|
@implementation ComposeWindowController
|
|
@@ -33,7 +34,7 @@
|
|
|
|
-(void) post: (id)sender
|
|
{
|
|
- Message *m=[[Message alloc] init];
|
|
+ CWMessage *m=[[CWMessage alloc] init];
|
|
NSMutableDictionary *md;
|
|
NSEnumerator *e;
|
|
NSString *header,*value;
|
|
@@ -64,7 +65,7 @@
|
|
|
|
if ([header isEqualToString: @"From"])
|
|
{
|
|
- InternetAddress *ia=[[InternetAddress alloc] initWithString: value];
|
|
+ CWInternetAddress *ia=[[CWInternetAddress alloc] initWithString: value];
|
|
[m setFrom: ia];
|
|
DESTROY(ia);
|
|
}
|
|
@@ -81,7 +82,14 @@
|
|
[m setFormat: PantomimeFormatFlowed];
|
|
[m setContent: [text string]];
|
|
|
|
- [m setCharset: [MimeUtility charsetForString: [text string]]];
|
|
+ if(![Pref_MessageViewing defaultEncoding])
|
|
+ {
|
|
+ [m setCharset: @"utf-8"];
|
|
+ }
|
|
+ else
|
|
+ {
|
|
+ [m setCharset: [Pref_MessageViewing defaultEncoding]];
|
|
+ }
|
|
|
|
state=1;
|
|
d=[m dataValue];
|
|
@@ -386,7 +394,7 @@
|
|
}
|
|
|
|
/* TODO: handle attributation, followup to sender, followup, etc. */
|
|
-- initWithFollowupToMessage: (Message *)msg
|
|
+- initWithFollowupToMessage: (CWMessage *)msg
|
|
{
|
|
NSDictionary *headers;
|
|
NSString *subject,*references;
|
|
diff -urNad lusernet.app-0.4.2~/FolderThreader.m FolderThreader.m
|
|
--- lusernet.app-0.4.2~/FolderThreader.m 2004-03-03 01:58:37.000000000 +0200
|
|
+++ FolderThreader.m 2006-09-27 00:13:21.000000000 +0300
|
|
@@ -9,7 +9,7 @@
|
|
|
|
#include "FolderThreader.h"
|
|
|
|
-#include <Pantomime/MimeUtility.h>
|
|
+#include <Pantomime/CWMIMEUtility.h>
|
|
|
|
|
|
static NSDate *parse_date(const char *date_header)
|
|
@@ -544,7 +544,7 @@
|
|
return @"";
|
|
|
|
d=[[NSData alloc] initWithBytes: c length: strlen(c)];
|
|
- s2=[MimeUtility decodeHeader: d charset: nil];
|
|
+ s2=[CWMIMEUtility decodeHeader: d charset: nil];
|
|
[d release];
|
|
return s2;
|
|
}
|
|
@@ -586,7 +586,7 @@
|
|
else
|
|
{
|
|
d=[[NSData alloc] initWithBytes: c length: strlen(c)];
|
|
- s2=[MimeUtility decodeHeader: d charset: nil];
|
|
+ s2=[CWMIMEUtility decodeHeader: d charset: nil];
|
|
[d release];
|
|
h->subject=[s2 retain];
|
|
}
|
|
@@ -595,7 +595,7 @@
|
|
if (c)
|
|
{
|
|
d=[[NSData alloc] initWithBytes: c length: strlen(c)];
|
|
- s2=[MimeUtility decodeHeader: d charset: nil];
|
|
+ s2=[CWMIMEUtility decodeHeader: d charset: nil];
|
|
[d release];
|
|
h->from=[s2 retain];
|
|
}
|
|
diff -urNad lusernet.app-0.4.2~/FolderWindowController.m FolderWindowController.m
|
|
--- lusernet.app-0.4.2~/FolderWindowController.m 2004-03-03 01:58:37.000000000 +0200
|
|
+++ FolderWindowController.m 2006-09-27 00:13:21.000000000 +0300
|
|
@@ -20,7 +20,8 @@
|
|
#include <AppKit/NSCell.h>
|
|
#include <AppKit/NSFont.h>
|
|
+#include <AppKit/NSEvent.h>
|
|
|
|
-#include <Pantomime/MimeUtility.h>
|
|
+#include <Pantomime/CWMIMEUtility.h>
|
|
|
|
#include "MsgDB.h"
|
|
|
|
diff -urNad lusernet.app-0.4.2~/MessageViewController.h MessageViewController.h
|
|
--- lusernet.app-0.4.2~/MessageViewController.h 2002-03-08 02:39:34.000000000 +0200
|
|
+++ MessageViewController.h 2006-09-27 00:13:21.000000000 +0300
|
|
@@ -6,7 +6,7 @@
|
|
#define MessageViewController_h
|
|
|
|
@class NSTextView,NSScrollView,NSMutableDictionary;
|
|
-@class Message;
|
|
+@class CWMessage;
|
|
|
|
#include "MsgDB.h"
|
|
|
|
@@ -17,7 +17,7 @@
|
|
|
|
MsgDB *mdb;
|
|
msg_id_t mid;
|
|
- Message *cur_message;
|
|
+ CWMessage *cur_message;
|
|
|
|
/* actually an NSMapTable */
|
|
void *cur_options;
|
|
@@ -48,6 +48,8 @@
|
|
|
|
-(void) messageSave;
|
|
|
|
+-(void) encodingChanged: (NSNotification *)n;
|
|
+
|
|
@end
|
|
|
|
#endif
|
|
diff -urNad lusernet.app-0.4.2~/MessageViewController.m MessageViewController.m
|
|
--- lusernet.app-0.4.2~/MessageViewController.m 2004-03-03 01:58:37.000000000 +0200
|
|
+++ MessageViewController.m 2006-09-27 00:13:21.000000000 +0300
|
|
@@ -5,6 +5,9 @@
|
|
#include <Foundation/NSObject.h>
|
|
#include <Foundation/NSBundle.h>
|
|
#include <Foundation/NSFileManager.h>
|
|
+#include <AppKit/NSAttributedString.h>
|
|
+#include <AppKit/NSGraphics.h>
|
|
+#include <AppKit/NSGraphicsContext.h>
|
|
#include <AppKit/NSFileWrapper.h>
|
|
#include <AppKit/NSTextView.h>
|
|
#include <AppKit/NSScrollView.h>
|
|
@@ -21,11 +21,11 @@
|
|
|
|
#include "GUISource.h"
|
|
|
|
-#include <Pantomime/Message.h>
|
|
-#include <Pantomime/MimeMultipart.h>
|
|
-#include <Pantomime/MimeUtility.h>
|
|
-#include <Pantomime/InternetAddress.h>
|
|
-#include <Pantomime/UUFile.h>
|
|
+#include <Pantomime/CWMessage.h>
|
|
+#include <Pantomime/CWMIMEMultipart.h>
|
|
+#include <Pantomime/CWMIMEUtility.h>
|
|
+#include <Pantomime/CWInternetAddress.h>
|
|
+#include <Pantomime/CWUUFile.h>
|
|
|
|
//#define USE_MIME_STUFF
|
|
|
|
@@ -89,7 +89,7 @@
|
|
|
|
|
|
@interface MessageViewController (private)
|
|
--(void) _renderContent:(id)p parent:(Part *)parent to:(NSMutableAttributedString *)str;
|
|
+-(void) _renderContent:(id)p parent:(CWPart *)parent to:(NSMutableAttributedString *)str;
|
|
-(void) _renderPart:(id)p to:(NSMutableAttributedString *)str;
|
|
|
|
-(void) displayMessage;
|
|
@@ -212,10 +212,10 @@
|
|
}
|
|
|
|
|
|
--(void) _render_multipart: (MimeMultipart *)mp type: (NSString *)ct
|
|
+-(void) _render_multipart: (CWMIMEMultipart *)mp type: (NSString *)ct
|
|
to: (NSMutableAttributedString *)str
|
|
{
|
|
- Part *bp;
|
|
+ CWPart *bp;
|
|
int i;
|
|
|
|
if ([ct isEqual: @"multipart/alternative"])
|
|
@@ -227,14 +227,14 @@
|
|
else
|
|
disp=[mp count]-1;
|
|
|
|
- bp=[mp bodyPartAtIndex: disp];
|
|
+ bp=[mp partAtIndex: disp];
|
|
append(str,header_bold_dict,_(@"Currently shown:"));
|
|
append(str,header_dict,@" %@\n",[bp contentType]);
|
|
append(str,header_bold_dict,_(@"Alternatives:"));
|
|
for (i=0;i<[mp count];i++)
|
|
{
|
|
appendLink(str,LINK_MULTIPART_ALTERNATIVE,mp,i+1,@" %@",
|
|
- [[mp bodyPartAtIndex: i] contentType]);
|
|
+ [[mp partAtIndex: i] contentType]);
|
|
}
|
|
append(str,nil,@"\n");
|
|
|
|
@@ -249,7 +249,7 @@
|
|
|
|
for (i=0;i<[mp count];i++)
|
|
{
|
|
- bp=[mp bodyPartAtIndex: i];
|
|
+ bp=[mp partAtIndex: i];
|
|
append(str,header_bold_dict,_(@"\nPart:"));
|
|
append(str,header_dict,@" %i %@\n",i,[bp contentType]);
|
|
[self _renderPart:bp to:str];
|
|
@@ -264,7 +264,7 @@
|
|
NSDictionary *fd;
|
|
NSFont *f;
|
|
|
|
- NSRange r;
|
|
+ // NSRange r;
|
|
|
|
if (cur_font)
|
|
f=[Pref_MessageViewing font2];
|
|
@@ -276,7 +276,7 @@
|
|
|
|
#if 0 /* TODO: need to update with new Pantomime interface */
|
|
/* TODO: this should probably be optional */
|
|
- r=[MimeUtility rangeOfUUEncodedStringFromString: text
|
|
+ r=[CWMIMEUtility rangeOfUUEncodedStringFromString: text
|
|
range: NSMakeRange(0,[text length])];
|
|
|
|
if (r.location==NSNotFound)
|
|
@@ -291,7 +291,7 @@
|
|
appendPlainText(str,fd,[text substringWithRange: NSMakeRange(0,r.location)]);
|
|
|
|
/* TODO: this is inefficient */
|
|
- fw=[MimeUtility fileWrapperFromUUEncodedString: [text substringWithRange: r]];
|
|
+ fw=[CWMIMEUtility fileWrapperFromUUEncodedString: [text substringWithRange: r]];
|
|
|
|
append(str,header_bold_dict,_(@"UUEncoded file:"));
|
|
append(str,header_dict,@" %@ ",[fw preferredFilename]);
|
|
@@ -312,7 +312,7 @@
|
|
}
|
|
|
|
|
|
--(void) _renderContent:(id)p parent:(Part *)parent
|
|
+-(void) _renderContent:(id)p parent:(CWPart *)parent
|
|
to:(NSMutableAttributedString *)str
|
|
{
|
|
NSString *ct=[parent contentType];
|
|
@@ -340,9 +340,9 @@
|
|
|
|
|
|
/* Some content classes/types we handle internally. */
|
|
- if ([p isKindOfClass: [MimeMultipart class]])
|
|
+ if ([p isKindOfClass: [CWMIMEMultipart class]])
|
|
{
|
|
- [self _render_multipart: (MimeMultipart *)p type: ct to: str];
|
|
+ [self _render_multipart: (CWMIMEMultipart *)p type: ct to: str];
|
|
return;
|
|
}
|
|
|
|
@@ -352,7 +352,7 @@
|
|
return;
|
|
}
|
|
|
|
- if ([p isKindOfClass: [Part class]])
|
|
+ if ([p isKindOfClass: [CWPart class]])
|
|
{
|
|
[self _renderPart: p to: str];
|
|
return;
|
|
@@ -553,13 +553,13 @@
|
|
|
|
-(void) _renderPart:(id)p to:(NSMutableAttributedString *)str
|
|
{
|
|
- if ([p isKindOfClass: [Message class]])
|
|
+ if ([p isKindOfClass: [CWMessage class]])
|
|
{
|
|
- Message *m=(Message *)p;
|
|
+ CWMessage *m=(CWMessage *)p;
|
|
append(str,header_bold_dict,_(@"Subject:"));
|
|
append(str,header_dict,@" %@\n",[m subject]);
|
|
append(str,header_bold_dict,_(@"From:"));
|
|
- append(str,header_dict,@" %@\n",[[m from] unicodeStringValue]);
|
|
+ append(str,header_dict,@" %@\n",[[m from] stringValue]);
|
|
append(str,header_bold_dict,_(@"Newsgroups:"));
|
|
append(str,header_dict,@" %@\n",[m headerValueForName: @"Newsgroups"]);
|
|
append(str,header_bold_dict,_(@"Date:"));
|
|
@@ -569,9 +569,9 @@
|
|
append(str,nil,@"\n");
|
|
[self _renderContent:[m content] parent: m to:str];
|
|
}
|
|
- else if ([p isKindOfClass: [Part class]])
|
|
+ else if ([p isKindOfClass: [CWPart class]])
|
|
{ /* handles MimeBodyPart and any extensions */
|
|
- [self _renderContent:[(Part *)p content] parent: (Part *)p to:str];
|
|
+ [self _renderContent:[(CWPart *)p content] parent: (CWPart *)p to:str];
|
|
}
|
|
else
|
|
{
|
|
@@ -655,7 +655,27 @@
|
|
NSData *d;
|
|
|
|
d=[[NSData alloc] initWithBytes: data length: length];
|
|
- cur_message=[(Message *)[Message alloc] initWithData: d];
|
|
+ if([mdb msg_getHeader: "ContentType" : mid])
|
|
+ {
|
|
+ cur_message=[(CWMessage *)[CWMessage alloc] initWithData: d];
|
|
+ }
|
|
+ else
|
|
+ {
|
|
+ cur_message=[(CWMessage *)[CWMessage alloc] initWithData: d
|
|
+ charset:[Pref_MessageViewing defaultEncoding]];
|
|
+ }
|
|
+ if(![cur_message contentType])
|
|
+ {
|
|
+ [cur_message setContentType:@"text/plain"];
|
|
+ }
|
|
+ else
|
|
+ {
|
|
+ ASSIGN(
|
|
+ cur_message,
|
|
+ [(CWMessage *)[CWMessage alloc] initWithData: d
|
|
+ charset:[cur_message charset]]
|
|
+ );
|
|
+ }
|
|
[d release];
|
|
{
|
|
const char *c;
|
|
@@ -819,17 +839,17 @@
|
|
{
|
|
NSString *s=(NSString *)l->object;
|
|
NSRange r;
|
|
- UUFile *fw;
|
|
- r=[MimeUtility rangeOfUUEncodedStringFromString: s
|
|
+ CWUUFile *fw;
|
|
+ r=[CWUUFile rangeOfUUEncodedStringFromString: s
|
|
range: NSMakeRange(0,[s length])];
|
|
|
|
- fw=[MimeUtility fileFromUUEncodedString: [s substringWithRange: r]];
|
|
+ fw=[CWUUFile fileFromUUEncodedString: [s substringWithRange: r]];
|
|
filename=AUTORELEASE(RETAIN([fw name]));
|
|
d=AUTORELEASE(RETAIN([fw data]));
|
|
}
|
|
else
|
|
{
|
|
- Part *p=(Part *)l->object;
|
|
+ CWPart *p=(CWPart *)l->object;
|
|
d=(NSData *)[p content];
|
|
filename=[p filename];
|
|
}
|
|
@@ -926,6 +946,12 @@
|
|
|
|
mid=0;
|
|
|
|
+ [[NSNotificationCenter defaultCenter]
|
|
+ addObserver: self
|
|
+ selector: @selector(encodingChanged:)
|
|
+ name: DefaultEncodingChangedNotification
|
|
+ object: nil];
|
|
+
|
|
return self;
|
|
}
|
|
|
|
@@ -1154,6 +1180,11 @@
|
|
[app_delegate composeFollowupToMessage: cur_message];
|
|
}
|
|
|
|
+-(void) encodingChanged: (NSNotification *)n
|
|
+{
|
|
+ [self getData];
|
|
+ [self displayMessage];
|
|
+}
|
|
|
|
@end
|
|
|
|
diff -urNad lusernet.app-0.4.2~/NNTPSourceGUI.m NNTPSourceGUI.m
|
|
--- lusernet.app-0.4.2~/NNTPSourceGUI.m 2004-03-03 01:58:37.000000000 +0200
|
|
+++ NNTPSourceGUI.m 2006-09-27 00:13:21.000000000 +0300
|
|
@@ -347,7 +347,6 @@
|
|
[win setTitle: _(@"NNTPSource properties")];
|
|
[win setDelegate: self];
|
|
[win autoSetupKeyViewChain];
|
|
- [win release];
|
|
|
|
return self;
|
|
}
|
|
diff -urNad lusernet.app-0.4.2~/Pref_MessageViewing.h Pref_MessageViewing.h
|
|
--- lusernet.app-0.4.2~/Pref_MessageViewing.h 2002-03-11 02:06:46.000000000 +0200
|
|
+++ Pref_MessageViewing.h 2006-09-27 00:13:21.000000000 +0300
|
|
@@ -27,6 +27,7 @@
|
|
|
|
+(NSFont *) font1;
|
|
+(NSFont *) font2;
|
|
++(NSString *) defaultEncoding;
|
|
|
|
@end
|
|
|
|
diff -urNad lusernet.app-0.4.2~/Pref_MessageViewing.m Pref_MessageViewing.m
|
|
--- lusernet.app-0.4.2~/Pref_MessageViewing.m 2004-03-03 01:58:37.000000000 +0200
|
|
+++ Pref_MessageViewing.m 2006-09-27 00:13:21.000000000 +0300
|
|
@@ -8,11 +8,15 @@
|
|
#include <Foundation/NSBundle.h>
|
|
|
|
#include <AppKit/NSButton.h>
|
|
+#include <AppKit/NSFontManager.h>
|
|
+#include <AppKit/NSPopUpButton.h>
|
|
#include <AppKit/NSTextField.h>
|
|
#include <GNUstepGUI/GSVbox.h>
|
|
#include <GNUstepGUI/GSHbox.h>
|
|
#include <AppKit/NSFont.h>
|
|
|
|
+#include <Pantomime/CWCharset.h>
|
|
+
|
|
#include "Pref_MessageViewing.h"
|
|
|
|
|
|
@@ -192,6 +195,7 @@
|
|
{
|
|
NSTextField *f;
|
|
NSButton *b;
|
|
+ NSPopUpButton *pop;
|
|
GSHbox *hb;
|
|
|
|
hb=[[GSHbox alloc] init];
|
|
@@ -289,6 +293,49 @@
|
|
|
|
[top addView: hb enablingYResizing: NO];
|
|
DESTROY(hb);
|
|
+
|
|
+ [top addSeparator];
|
|
+
|
|
+ hb=[[GSHbox alloc] init];
|
|
+ [hb setDefaultMinXMargin: 4];
|
|
+ [hb setAutoresizingMask: NSViewWidthSizable];
|
|
+
|
|
+ f=[[NSTextField alloc] init];
|
|
+ [f setStringValue: _(@"Default encoding ")];
|
|
+ [f setEditable: NO];
|
|
+ [f setDrawsBackground: NO];
|
|
+ [f setBordered: NO];
|
|
+ [f setBezeled: NO];
|
|
+ [f setSelectable: NO];
|
|
+ [f sizeToFit];
|
|
+ [f setAutoresizingMask: 0];
|
|
+ [hb addView: f enablingXResizing: NO];
|
|
+ DESTROY(f);
|
|
+
|
|
+ pop = [[NSPopUpButton alloc] init];
|
|
+ [pop setPullsDown:NO];
|
|
+ NSDictionary *charsets = [CWCharset allCharsets];
|
|
+ NSEnumerator *en = [[charsets allValues] objectEnumerator];
|
|
+ NSString *encoding;
|
|
+ while((encoding = [en nextObject]))
|
|
+ {
|
|
+ [pop addItemWithTitle:encoding];
|
|
+ }
|
|
+ [pop selectItemWithTitle:
|
|
+ [charsets
|
|
+ objectForKey:
|
|
+ [sd objectForKey:@"DefaultEncoding"]]];
|
|
+ [pop synchronizeTitleAndSelectedItem];
|
|
+ [pop setTarget: self];
|
|
+ [pop setAction: @selector(changeEncoding:)];
|
|
+ [pop sizeToFit];
|
|
+ [hb addView: pop enablingXResizing: NO];
|
|
+ DESTROY(pop);
|
|
+
|
|
+
|
|
+ [top addView: hb enablingYResizing: NO];
|
|
+ DESTROY(hb);
|
|
+
|
|
}
|
|
|
|
[self revert];
|
|
@@ -334,5 +381,23 @@
|
|
[f_cur setFont: f];
|
|
}
|
|
|
|
+-(void) changeEncoding:(id)sender
|
|
+{
|
|
+ NSDictionary *charsets = [CWCharset allCharsets];
|
|
+ sd=[NSUserDefaults standardUserDefaults];
|
|
+
|
|
+ [sender selectItemWithTitle:[sender titleOfSelectedItem]];
|
|
+ [sender synchronizeTitleAndSelectedItem];
|
|
+
|
|
+ [sd setObject:
|
|
+ [[charsets allKeysForObject:[sender titleOfSelectedItem]] objectAtIndex:0]
|
|
+ forKey:@"DefaultEncoding"];
|
|
+}
|
|
+
|
|
++(NSString *) defaultEncoding
|
|
+{
|
|
+ return [sd stringForKey:@"DefaultEncoding"];
|
|
+}
|
|
+
|
|
@end
|
|
|
|
diff -urNad lusernet.app-0.4.2~/main.h main.h
|
|
--- lusernet.app-0.4.2~/main.h 2004-03-03 01:58:37.000000000 +0200
|
|
+++ main.h 2006-09-27 00:13:21.000000000 +0300
|
|
@@ -11,6 +11,8 @@
|
|
@class FolderListController,LogWindowController,PreferencesWindowController;
|
|
@class Message;
|
|
|
|
+extern NSString *DefaultEncodingChangedNotification;
|
|
+
|
|
@interface AppDelegate : NSObject
|
|
{
|
|
NSApplication *app;
|
|
@@ -37,7 +39,7 @@
|
|
@interface AppDelegate (prefs)
|
|
-(void) openPreferences: (id)sender;
|
|
@end
|
|
-
|
|
+
|
|
|
|
extern AppDelegate *app_delegate;
|
|
|
|
diff -urNad lusernet.app-0.4.2~/main.m main.m
|
|
--- lusernet.app-0.4.2~/main.m 2004-03-03 01:58:37.000000000 +0200
|
|
+++ main.m 2006-09-27 00:13:21.000000000 +0300
|
|
@@ -8,9 +8,12 @@
|
|
#include <Foundation/NSPathUtilities.h>
|
|
#include <Foundation/NSBundle.h>
|
|
#include <AppKit/NSApplication.h>
|
|
+#include <AppKit/NSGraphics.h>
|
|
#include <AppKit/NSMenu.h>
|
|
#include <AppKit/NSWindow.h>
|
|
|
|
+#include <Pantomime/CWCharset.h>
|
|
+
|
|
#include "MsgDB.h"
|
|
|
|
#include "LogWindowController.h"
|
|
@@ -36,6 +38,7 @@
|
|
|
|
#define LocationKey @"MessageDatabaseLocation"
|
|
|
|
+NSString *DefaultEncodingChangedNotification = @"DefaultEncodingChangedNotification";
|
|
|
|
@interface NSMenu (im_lazy)
|
|
-(id <NSMenuItem>) addItemWithTitle: (NSString *)s;
|
|
@@ -209,6 +212,21 @@
|
|
#endif
|
|
}
|
|
|
|
+-(void) changeEncoding:(id)sender
|
|
+{
|
|
+ NSDictionary *charsets = [CWCharset allCharsets];
|
|
+
|
|
+ // [sender selectItemWithTitle:[sender title]];
|
|
+ // [sender synchronizeTitleAndSelectedItem];
|
|
+
|
|
+ [[NSUserDefaults standardUserDefaults] setObject:
|
|
+ [[charsets allKeysForObject:[sender title]] objectAtIndex:0]
|
|
+ forKey:@"DefaultEncoding"];
|
|
+
|
|
+ [[NSNotificationCenter defaultCenter]
|
|
+ postNotificationName: DefaultEncodingChangedNotification
|
|
+ object: nil];
|
|
+}
|
|
|
|
-(void) applicationWillFinishLaunching: (NSNotification *)n
|
|
{
|
|
@@ -307,6 +325,18 @@
|
|
m=[[NSMenu alloc] init];
|
|
/* [m addItemWithTitle: _(@"Open")
|
|
action: @selector(openMessage:)];*/
|
|
+ m2=[[NSMenu alloc] init];
|
|
+
|
|
+ NSDictionary *charsets = [CWCharset allCharsets];
|
|
+ NSEnumerator *en = [[charsets allValues] objectEnumerator];
|
|
+ NSString *encoding;
|
|
+ while((encoding = [en nextObject]))
|
|
+ {
|
|
+ [m2 addItemWithTitle: encoding
|
|
+ action: @selector(changeEncoding:)];
|
|
+ }
|
|
+
|
|
+ [m setSubmenu: m2 forItem: [m addItemWithTitle: _(@"Change encoding...")]];
|
|
[m addItemWithTitle: _(@"Toggle read/unread")
|
|
action: @selector(messageToggleRead:)
|
|
keyEquivalent: @"m"];
|