]> git.saurik.com Git - cydia.git/blob - CyteKit/ViewController.h
Re-add package-level Support as override for Bugs.
[cydia.git] / CyteKit / ViewController.h
1 /* Cydia - iPhone UIKit Front-End for Debian APT
2 * Copyright (C) 2008-2013 Jay Freeman (saurik)
3 */
4
5 /* GNU General Public License, Version 3 {{{ */
6 /*
7 * Cydia is free software: you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published
9 * by the Free Software Foundation, either version 3 of the License,
10 * or (at your option) any later version.
11 *
12 * Cydia is distributed in the hope that it will be useful, but
13 * WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with Cydia. If not, see <http://www.gnu.org/licenses/>.
19 **/
20 /* }}} */
21
22 #ifndef CyteKit_ViewController_H
23 #define CyteKit_ViewController_H
24
25 #include <CyteKit/UCPlatform.h>
26
27 #include <UIKit/UIKit.h>
28
29 @interface UIViewController (Cydia)
30 - (BOOL) hasLoaded;
31 - (void) reloadData;
32 - (void) unloadData;
33 - (UIViewController *) parentOrPresentingViewController;
34 @end
35
36 @interface CyteViewController : UIViewController {
37 _transient id delegate_;
38 BOOL loaded_;
39 }
40
41 // The default implementation of this method is essentially a no-op,
42 // but calling the superclass implementation is *required*.
43 - (void) reloadData;
44
45 - (void) unloadData;
46
47 // This URL is used to save the state of the view controller. Return
48 // nil if you cannot or should not save the URL for this page.
49 - (NSURL *) navigationURL;
50
51 // By default, this delegate is unused. However, it's provided here in case
52 // you need some kind of delegate in a subclass.
53 - (void) setDelegate:(id)delegate;
54 - (id) delegate;
55
56 // Override this in subclasses if you manage the "has seen first load" state yourself.
57 - (BOOL) hasLoaded;
58
59 // This is called when the view managed by the view controller is released.
60 // That is not always when the controller itself is released: it also can
61 // happen when more memory is needed by the system or whenever the controller
62 // just happens not to be visible.
63 - (void) releaseSubviews;
64
65 @end
66
67 #endif//CyteKit_ViewController_H