Develop and Download Open Source Software

Browse Subversion Repository

Annotation of /XspfManager/XspfManager_Debugging.m

Parent Directory Parent Directory | Revision Log Revision Log


Revision 460 - (hide annotations) (download)
Sun Dec 26 08:03:45 2010 UTC (13 years, 3 months ago) by masakih
Original Path: branches/withBuildInPlayer/XspfManager_Debugging.m
File size: 7500 byte(s)
[Mod] デバッグ用コードを別ファイルに分離。
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     - (BOOL)validateMenuItem:(NSMenuItem *)menuItem
82     {
83     SEL action = [menuItem action];
84     NSInteger tag = [menuItem tag];
85    
86     NSUserDefaults *ud = [NSUserDefaults standardUserDefaults];
87    
88     if(action == @selector(toggleEnableLog:)) {
89     if([ud boolForKey:@"HMLogEnable"]) {
90     [menuItem setTitle:@"Disable log"];
91     } else {
92     [menuItem setTitle:@"Enable log"];
93     }
94     return YES;
95     }
96    
97     if(action == @selector(changeLogLevel:)) {
98     NSInteger level = [ud integerForKey:@"HMLogLevel"];
99     if(level == tag) {
100     [menuItem setState:NSOnState];
101     } else {
102     [menuItem setState:NSOffState];
103     }
104     return YES;
105     }
106    
107     if(action == @selector(launchXspfQT:)) {
108     NSString *launchAppMenuLabelFormat = NSLocalizedString(@"Launch %@", @"Launch application menu label.");
109     NSString *launchAppMenuLabel = [NSString stringWithFormat:launchAppMenuLabelFormat, [XspfMPreferences sharedPreference].playerName];
110     [menuItem setTitle:launchAppMenuLabel];
111     return YES;
112     }
113    
114     return YES;
115     }
116     - (void)setupDebugMenu
117     {
118     NSUserDefaults *ud = [NSUserDefaults standardUserDefaults];
119     if(![ud boolForKey:@"HMEnableDebugMenu"]) return;
120    
121     NSMenu *debugMenu = [[[NSMenu alloc] initWithTitle:@"Debug"] autorelease];
122     NSMenuItem *enableLogItem = [[[NSMenuItem alloc] initWithTitle:@"Enable log"
123     action:@selector(toggleEnableLog:)
124     keyEquivalent:@""] autorelease];
125     [debugMenu addItem:enableLogItem];
126    
127     [debugMenu addItem:[NSMenuItem separatorItem]];
128    
129     NSMenuItem *logLevelItem = [[[NSMenuItem alloc] initWithTitle:@"Debug level"
130     action:@selector(changeLogLevel:)
131     keyEquivalent:@""] autorelease];
132     [logLevelItem setTag:HMLogLevelDebug];
133     [debugMenu addItem:logLevelItem];
134    
135     logLevelItem = [[[NSMenuItem alloc] initWithTitle:@"Notice level"
136     action:@selector(changeLogLevel:)
137     keyEquivalent:@""] autorelease];
138     [logLevelItem setTag:HMLogLevelNotice];
139     [debugMenu addItem:logLevelItem];
140    
141     logLevelItem = [[[NSMenuItem alloc] initWithTitle:@"Caution level"
142     action:@selector(changeLogLevel:)
143     keyEquivalent:@""] autorelease];
144     [logLevelItem setTag:HMLogLevelCaution];
145     [debugMenu addItem:logLevelItem];
146    
147     logLevelItem = [[[NSMenuItem alloc] initWithTitle:@"Alert level"
148     action:@selector(changeLogLevel:)
149     keyEquivalent:@""] autorelease];
150     [logLevelItem setTag:HMLogLevelAlert];
151     [debugMenu addItem:logLevelItem];
152    
153     [debugMenu addItem:[NSMenuItem separatorItem]];
154    
155     NSMenuItem *testItem;
156    
157     testItem = [[[NSMenuItem alloc] initWithTitle:@"test01"
158     action:@selector(test01:)
159     keyEquivalent:@""] autorelease];
160     [debugMenu addItem:testItem];
161    
162     testItem = [[[NSMenuItem alloc] initWithTitle:@"test02"
163     action:@selector(test02:)
164     keyEquivalent:@""] autorelease];
165     [debugMenu addItem:testItem];
166    
167     testItem = [[[NSMenuItem alloc] initWithTitle:@"test03"
168     action:@selector(test03:)
169     keyEquivalent:@""] autorelease];
170     [debugMenu addItem:testItem];
171    
172     NSMenu *menubar = [NSApp mainMenu];
173     NSUInteger itemCount = [[menubar itemArray] count];
174     NSMenuItem *debugMenuItem = [menubar insertItemWithTitle:@"Debug"
175     action:Nil
176     keyEquivalent:@""
177     atIndex:itemCount - 1];
178     [debugMenuItem setSubmenu:debugMenu];
179     }
180    
181     - (void)test03:(id)sender
182     {
183     NSResponder *responder = [NSApp keyWindow].firstResponder;
184    
185     while(responder) {
186     NSLog(@"\t%@", responder);
187     responder = responder.nextResponder;
188     }
189     }
190    
191     @end

Back to OSDN">Back to OSDN
ViewVC Help
Powered by ViewVC 1.1.26