| 1 |
masakih |
460 |
// |
| 2 |
|
|
// XspfManager_Debugging.m |
| 3 |
|
|
// XspfManager |
| 4 |
|
|
// |
| 5 |
|
|
// Created by Hori,Masaki on 10/12/26. |
| 6 |
|
|
// |
| 7 |
|
|
|
| 8 |
|
|
/* |
| 9 |
|
|
This source code is release under the New BSD License. |
| 10 |
|
|
Copyright (c) 2010, masakih |
| 11 |
|
|
All rights reserved. |
| 12 |
|
|
|
| 13 |
|
|
ソースコード形式かバイナリ形式か、変更するかしないかを問わず、以下の条件を満たす場合に |
| 14 |
|
|
限り、再頒布および使用が許可されます。 |
| 15 |
|
|
|
| 16 |
|
|
1, ソースコードを再頒布する場合、上記の著作権表示、本条件一覧、および下記免責条項を含 |
| 17 |
|
|
めること。 |
| 18 |
|
|
2, バイナリ形式で再頒布する場合、頒布物に付属のドキュメント等の資料に、上記の著作権表 |
| 19 |
|
|
示、本条件一覧、および下記免責条項を含めること。 |
| 20 |
|
|
3, 書面による特別の許可なしに、本ソフトウェアから派生した製品の宣伝または販売促進に、 |
| 21 |
|
|
コントリビューターの名前を使用してはならない。 |
| 22 |
|
|
本ソフトウェアは、著作権者およびコントリビューターによって「現状のまま」提供されており、 |
| 23 |
|
|
明示黙示を問わず、商業的な使用可能性、および特定の目的に対する適合性に関する暗黙の保証 |
| 24 |
|
|
も含め、またそれに限定されない、いかなる保証もありません。著作権者もコントリビューター |
| 25 |
|
|
も、事由のいかんを問わず、 損害発生の原因いかんを問わず、かつ責任の根拠が契約であるか |
| 26 |
|
|
厳格責任であるか(過失その他の)不法行為であるかを問わず、仮にそのような損害が発生する |
| 27 |
|
|
可能性を知らされていたとしても、本ソフトウェアの使用によって発生した(代替品または代用 |
| 28 |
|
|
サービスの調達、使用の喪失、データの喪失、利益の喪失、業務の中断も含め、またそれに限定 |
| 29 |
|
|
されない)直接損害、間接損害、偶発的な損害、特別損害、懲罰的損害、または結果損害につい |
| 30 |
|
|
て、一切責任を負わないものとします。 |
| 31 |
|
|
------------------------------------------------------------------- |
| 32 |
|
|
Copyright (c) 2010, masakih |
| 33 |
|
|
All rights reserved. |
| 34 |
|
|
|
| 35 |
|
|
Redistribution and use in source and binary forms, with or without |
| 36 |
|
|
modification, are permitted provided that the following conditions |
| 37 |
|
|
are met: |
| 38 |
|
|
|
| 39 |
|
|
1, Redistributions of source code must retain the above copyright |
| 40 |
|
|
notice, this list of conditions and the following disclaimer. |
| 41 |
|
|
2, Redistributions in binary form must reproduce the above copyright |
| 42 |
|
|
notice, this list of conditions and the following disclaimer in |
| 43 |
|
|
the documentation and/or other materials provided with the |
| 44 |
|
|
distribution. |
| 45 |
|
|
3, The names of its contributors may be used to endorse or promote |
| 46 |
|
|
products derived from this software without specific prior |
| 47 |
|
|
written permission. |
| 48 |
|
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
| 49 |
|
|
"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
| 50 |
|
|
LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS |
| 51 |
|
|
FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE |
| 52 |
|
|
COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, |
| 53 |
|
|
INCIDENTAL, SPECIAL,EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, |
| 54 |
|
|
BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; |
| 55 |
|
|
LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER |
| 56 |
|
|
CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT |
| 57 |
|
|
LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN |
| 58 |
|
|
ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE |
| 59 |
|
|
POSSIBILITY OF SUCH DAMAGE. |
| 60 |
|
|
*/ |
| 61 |
|
|
|
| 62 |
|
|
|
| 63 |
|
|
#import "XspfManager.h" |
| 64 |
|
|
|
| 65 |
|
|
#import "XspfMPreferences.h" |
| 66 |
|
|
|
| 67 |
|
|
|
| 68 |
|
|
@implementation XspfManager(Debugging) |
| 69 |
|
|
|
| 70 |
|
|
-(IBAction)toggleEnableLog:(id)sender |
| 71 |
|
|
{ |
| 72 |
|
|
NSUserDefaults *ud = [NSUserDefaults standardUserDefaults]; |
| 73 |
|
|
[ud setBool:![ud boolForKey:@"HMLogEnable"] forKey:@"HMLogEnable"]; |
| 74 |
|
|
} |
| 75 |
|
|
- (IBAction)changeLogLevel:(id)sender |
| 76 |
|
|
{ |
| 77 |
|
|
NSInteger level = [sender tag]; |
| 78 |
|
|
NSUserDefaults *ud = [NSUserDefaults standardUserDefaults]; |
| 79 |
|
|
[ud setInteger:level forKey:@"HMLogLevel"]; |
| 80 |
|
|
} |
| 81 |
|
|
- (void)setupDebugMenu |
| 82 |
|
|
{ |
| 83 |
|
|
NSUserDefaults *ud = [NSUserDefaults standardUserDefaults]; |
| 84 |
|
|
if(![ud boolForKey:@"HMEnableDebugMenu"]) return; |
| 85 |
|
|
|
| 86 |
|
|
NSMenu *debugMenu = [[[NSMenu alloc] initWithTitle:@"Debug"] autorelease]; |
| 87 |
|
|
NSMenuItem *enableLogItem = [[[NSMenuItem alloc] initWithTitle:@"Enable log" |
| 88 |
|
|
action:@selector(toggleEnableLog:) |
| 89 |
|
|
keyEquivalent:@""] autorelease]; |
| 90 |
|
|
[debugMenu addItem:enableLogItem]; |
| 91 |
|
|
|
| 92 |
|
|
[debugMenu addItem:[NSMenuItem separatorItem]]; |
| 93 |
|
|
|
| 94 |
|
|
NSMenuItem *logLevelItem = [[[NSMenuItem alloc] initWithTitle:@"Debug level" |
| 95 |
|
|
action:@selector(changeLogLevel:) |
| 96 |
|
|
keyEquivalent:@""] autorelease]; |
| 97 |
|
|
[logLevelItem setTag:HMLogLevelDebug]; |
| 98 |
|
|
[debugMenu addItem:logLevelItem]; |
| 99 |
|
|
|
| 100 |
|
|
logLevelItem = [[[NSMenuItem alloc] initWithTitle:@"Notice level" |
| 101 |
|
|
action:@selector(changeLogLevel:) |
| 102 |
|
|
keyEquivalent:@""] autorelease]; |
| 103 |
|
|
[logLevelItem setTag:HMLogLevelNotice]; |
| 104 |
|
|
[debugMenu addItem:logLevelItem]; |
| 105 |
|
|
|
| 106 |
|
|
logLevelItem = [[[NSMenuItem alloc] initWithTitle:@"Caution level" |
| 107 |
|
|
action:@selector(changeLogLevel:) |
| 108 |
|
|
keyEquivalent:@""] autorelease]; |
| 109 |
|
|
[logLevelItem setTag:HMLogLevelCaution]; |
| 110 |
|
|
[debugMenu addItem:logLevelItem]; |
| 111 |
|
|
|
| 112 |
|
|
logLevelItem = [[[NSMenuItem alloc] initWithTitle:@"Alert level" |
| 113 |
|
|
action:@selector(changeLogLevel:) |
| 114 |
|
|
keyEquivalent:@""] autorelease]; |
| 115 |
|
|
[logLevelItem setTag:HMLogLevelAlert]; |
| 116 |
|
|
[debugMenu addItem:logLevelItem]; |
| 117 |
|
|
|
| 118 |
|
|
[debugMenu addItem:[NSMenuItem separatorItem]]; |
| 119 |
|
|
|
| 120 |
|
|
NSMenuItem *testItem; |
| 121 |
|
|
|
| 122 |
|
|
testItem = [[[NSMenuItem alloc] initWithTitle:@"test01" |
| 123 |
|
|
action:@selector(test01:) |
| 124 |
|
|
keyEquivalent:@""] autorelease]; |
| 125 |
|
|
[debugMenu addItem:testItem]; |
| 126 |
|
|
|
| 127 |
|
|
testItem = [[[NSMenuItem alloc] initWithTitle:@"test02" |
| 128 |
|
|
action:@selector(test02:) |
| 129 |
|
|
keyEquivalent:@""] autorelease]; |
| 130 |
|
|
[debugMenu addItem:testItem]; |
| 131 |
|
|
|
| 132 |
|
|
testItem = [[[NSMenuItem alloc] initWithTitle:@"test03" |
| 133 |
|
|
action:@selector(test03:) |
| 134 |
|
|
keyEquivalent:@""] autorelease]; |
| 135 |
|
|
[debugMenu addItem:testItem]; |
| 136 |
|
|
|
| 137 |
|
|
NSMenu *menubar = [NSApp mainMenu]; |
| 138 |
|
|
NSUInteger itemCount = [[menubar itemArray] count]; |
| 139 |
|
|
NSMenuItem *debugMenuItem = [menubar insertItemWithTitle:@"Debug" |
| 140 |
|
|
action:Nil |
| 141 |
|
|
keyEquivalent:@"" |
| 142 |
|
|
atIndex:itemCount - 1]; |
| 143 |
|
|
[debugMenuItem setSubmenu:debugMenu]; |
| 144 |
|
|
} |
| 145 |
|
|
|
| 146 |
|
|
- (void)test03:(id)sender |
| 147 |
|
|
{ |
| 148 |
|
|
NSResponder *responder = [NSApp keyWindow].firstResponder; |
| 149 |
|
|
|
| 150 |
|
|
while(responder) { |
| 151 |
|
|
NSLog(@"\t%@", responder); |
| 152 |
|
|
responder = responder.nextResponder; |
| 153 |
|
|
} |
| 154 |
|
|
} |
| 155 |
|
|
|
| 156 |
|
|
@end |