Completed
Push — issues/1132 ( b0ddd9...34d612 )
by Ravinder
22:33 queued 02:37
created

Give   A

Complexity

Total Complexity 24

Size/Duplication

Total Lines 485
Duplicated Lines 0 %

Coupling/Cohesion

Components 2
Dependencies 15

Importance

Changes 0
Metric Value
dl 0
loc 485
rs 9.1666
c 0
b 0
f 0
wmc 24
lcom 2
cbo 15

9 Methods

Rating   Name   Duplication   Size   Complexity  
A instance() 0 7 2
A __construct() 0 7 1
A init_hooks() 0 4 1
B init() 0 38 1
A __clone() 0 4 1
A __wakeup() 0 4 1
D setup_constants() 0 37 8
B includes() 0 131 6
A load_textdomain() 0 15 3
1
<?php
0 ignored issues
show
Coding Style Compatibility introduced by
For compatibility and reusability of your code, PSR1 recommends that a file should introduce either new symbols (like classes, functions, etc.) or have side-effects (like outputting something, or including other files), but not both at the same time. The first symbol is defined on line 53 and the first side effect is on line 43.

The PSR-1: Basic Coding Standard recommends that a file should either introduce new symbols, that is classes, functions, constants or similar, or have side effects. Side effects are anything that executes logic, like for example printing output, changing ini settings or writing to a file.

The idea behind this recommendation is that merely auto-loading a class should not change the state of an application. It also promotes a cleaner style of programming and makes your code less prone to errors, because the logic is not spread out all over the place.

To learn more about the PSR-1, please see the PHP-FIG site on the PSR-1.

Loading history...
2
/**
3
 * Plugin Name: Give - Donation Plugin
4
 * Plugin URI: https://givewp.com
5
 * Description: The most robust, flexible, and intuitive way to accept donations on WordPress.
6
 * Author: WordImpress
7
 * Author URI: https://wordimpress.com
8
 * Version: 2.0.0
9
 * Text Domain: give
10
 * Domain Path: /languages
11
 * GitHub Plugin URI: https://github.com/WordImpress/Give
12
 *
13
 * Give is free software: you can redistribute it and/or modify
14
 * it under the terms of the GNU General Public License as published by
15
 * the Free Software Foundation, either version 3 of the License, or
16
 * any later version.
17
 *
18
 * Give is distributed in the hope that it will be useful,
19
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
20
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21
 * GNU General Public License for more details.
22
 *
23
 * You should have received a copy of the GNU General Public License
24
 * along with Give. If not, see <https://www.gnu.org/licenses/>.
25
 *
26
 * A Tribute to Open Source:
27
 *
28
 * "Open source software is software that can be freely used, changed, and shared (in modified or unmodified form) by anyone. Open
29
 * source software is made by many people, and distributed under licenses that comply with the Open Source Definition."
30
 *
31
 * -- The Open Source Initiative
32
 *
33
 * Give is a tribute to the spirit and philosophy of Open Source. We at WordImpress gladly embrace the Open Source philosophy both
34
 * in how Give itself was developed, and how we hope to see others build more from our code base.
35
 *
36
 * Give would not have been possible without the tireless efforts of WordPress and the surrounding Open Source projects and their talented developers. Thank you all for your contribution to WordPress.
37
 *
38
 * - The WordImpress Team
39
 */
40
41
// Exit if accessed directly.
42
if ( ! defined( 'ABSPATH' ) ) {
43
	exit;
44
}
45
46
if ( ! class_exists( 'Give' ) ) :
47
48
	/**
49
	 * Main Give Class
50
	 *
51
	 * @since 1.0
52
	 */
53
	final class Give {
54
55
		/** Singleton *************************************************************/
56
57
		/**
58
		 * Give Instance
59
		 *
60
		 * @since  1.0
61
		 * @access private
62
		 *
63
		 * @var    Give() The one true Give
64
		 */
65
		protected static $_instance;
66
67
		/**
68
		 * Give Roles Object
69
		 *
70
		 * @since  1.0
71
		 * @access public
72
		 *
73
		 * @var    Give_Roles object
74
		 */
75
		public $roles;
76
77
		/**
78
		 * Give Settings Object
79
		 *
80
		 * @since  1.0
81
		 * @access public
82
		 *
83
		 * @var    Give_Plugin_Settings object
84
		 */
85
		public $give_settings;
86
87
		/**
88
		 * Give Session Object
89
		 *
90
		 * This holds donation data for user's session.
91
		 *
92
		 * @since  1.0
93
		 * @access public
94
		 *
95
		 * @var    Give_Session object
96
		 */
97
		public $session;
98
99
		/**
100
		 * Give HTML Element Helper Object
101
		 *
102
		 * @since  1.0
103
		 * @access public
104
		 *
105
		 * @var    Give_HTML_Elements object
106
		 */
107
		public $html;
108
109
		/**
110
		 * Give Emails Object
111
		 *
112
		 * @since  1.0
113
		 * @access public
114
		 *
115
		 * @var    Give_Emails object
116
		 */
117
		public $emails;
118
119
		/**
120
		 * Give Email Template Tags Object
121
		 *
122
		 * @since  1.0
123
		 * @access public
124
		 *
125
		 * @var    Give_Email_Template_Tags object
126
		 */
127
		public $email_tags;
128
129
		/**
130
		 * Give Donors DB Object
131
		 *
132
		 * @since  1.0
133
		 * @access public
134
		 *
135
		 * @var    Give_DB_Donors object
136
		 */
137
		public $donors;
138
139
		/**
140
		 * Give Donor meta DB Object
141
		 *
142
		 * @since  1.6
143
		 * @access public
144
		 *
145
		 * @var    Give_DB_Donor_Meta object
146
		 */
147
		public $donor_meta;
148
149
		/**
150
		 * Give API Object
151
		 *
152
		 * @since  1.0
153
		 * @access public
154
		 *
155
		 * @var    Give_API object
156
		 */
157
		public $api;
158
159
		/**
160
		 * Give Template Loader Object
161
		 *
162
		 * @since  1.0
163
		 * @access public
164
		 *
165
		 * @var    Give_Template_Loader object
166
		 */
167
		public $template_loader;
168
169
		/**
170
		 * Give No Login Object
171
		 *
172
		 * @since  1.0
173
		 * @access public
174
		 *
175
		 * @var    Give_Email_Access object
176
		 */
177
		public $email_access;
178
179
		/**
180
		 * Give_tooltips Object
181
		 *
182
		 * @since  2.0
183
		 * @access public
184
		 *
185
		 * @var    Give_Tooltips object
186
		 */
187
		public $tooltips;
188
189
		/**
190
		 * Give notices Object
191
		 *
192
		 * @var    Give_Notices $notices
193
		 */
194
		public $notices;
195
		
196
197
		/**
198
		 * Give logging Object
199
		 *
200
		 * @var    Give_Logging $logs
201
		 */
202
		public $logs;
203
204
		/**
205
		 * Give payment meta Object
206
		 *
207
		 * @var    Give_DB_Payment_Meta $notices
208
		 */
209
		public $payment_meta;
210
211
		/**
212
		 * Main Give Instance
213
		 *
214
		 * Ensures that only one instance of Give exists in memory at any one
215
		 * time. Also prevents needing to define globals all over the place.
216
		 *
217
		 * @since     1.0
218
		 * @access    public
219
		 *
220
		 * @static
221
		 * @see       Give()
222
		 *
223
		 * @return    Give
224
		 */
225
		public static function instance() {
226
			if ( is_null( self::$_instance ) ) {
227
				self::$_instance = new self();
228
			}
229
230
			return self::$_instance;
231
		}
232
233
		/**
234
		 * Give Constructor.
235
		 */
236
		public function __construct() {
237
			$this->setup_constants();
238
			$this->includes();
239
			$this->init_hooks();
240
241
			do_action( 'give_loaded' );
242
		}
243
244
		/**
245
		 * Hook into actions and filters.
246
		 *
247
		 * @since  1.8.9
248
		 */
249
		private function init_hooks() {
250
			register_activation_hook( __FILE__, 'give_install' );
251
			add_action( 'plugins_loaded', array( $this, 'init' ), 0 );
252
		}
253
254
		/**
255
		 * Init Give when WordPress Initializes.
256
		 *
257
		 * @since 1.8.9
258
		 */
259
		public function init() {
260
261
			/**
262
			 * Fires before the Give core is initialized.
263
			 *
264
			 * @since 1.8.9
265
			 */
266
			do_action( 'before_give_init' );
267
268
			// Set up localization.
269
			$this->load_textdomain();
270
271
			$this->roles           = new Give_Roles();
272
			$this->api             = new Give_API();
273
			$this->give_settings   = new Give_Admin_Settings();
274
			$this->session         = new Give_Session();
275
			$this->html            = new Give_HTML_Elements();
276
			$this->emails          = new Give_Emails();
277
			$this->email_tags      = new Give_Email_Template_Tags();
278
			$this->donors          = new Give_DB_Donors();
279
			$this->donor_meta      = new Give_DB_Donor_Meta();
280
			$this->template_loader = new Give_Template_Loader();
281
			$this->email_access    = new Give_Email_Access();
282
			$this->tooltips        = new Give_Tooltips();
283
			$this->notices         = new Give_Notices();
284
			$this->payment_meta    = new Give_DB_Payment_Meta();
285
			$this->logs            = new Give_Logging();
286
287
			/**
288
			 * Fire the action after Give core loads.
289
			 *
290
			 * @param class Give class instance.
291
			 *
292
			 * @since 1.8.7
293
			 */
294
			do_action( 'give_init', $this );
295
296
		}
297
298
		/**
299
		 * Throw error on object clone
300
		 *
301
		 * The whole idea of the singleton design pattern is that there is a single
302
		 * object, therefore we don't want the object to be cloned.
303
		 *
304
		 * @since  1.0
305
		 * @access protected
306
		 *
307
		 * @return void
308
		 */
309
		public function __clone() {
310
			// Cloning instances of the class is forbidden.
311
			_doing_it_wrong( __FUNCTION__, __( 'Cheatin&#8217; huh?', 'give' ), '1.0' );
312
		}
313
314
		/**
315
		 * Disable unserializing of the class
316
		 *
317
		 * @since  1.0
318
		 * @access protected
319
		 *
320
		 * @return void
321
		 */
322
		public function __wakeup() {
323
			// Unserializing instances of the class is forbidden.
324
			_doing_it_wrong( __FUNCTION__, __( 'Cheatin&#8217; huh?', 'give' ), '1.0' );
325
		}
326
327
		/**
328
		 * Setup plugin constants
329
		 *
330
		 * @since  1.0
331
		 * @access private
332
		 *
333
		 * @return void
334
		 */
335
		private function setup_constants() {
336
337
			// Plugin version
338
			if ( ! defined( 'GIVE_VERSION' ) ) {
339
				define( 'GIVE_VERSION', '2.0.0' );
340
			}
341
342
			// Plugin Folder Path
343
			if ( ! defined( 'GIVE_PLUGIN_DIR' ) ) {
344
				define( 'GIVE_PLUGIN_DIR', plugin_dir_path( __FILE__ ) );
345
			}
346
347
			// Plugin Folder URL
348
			if ( ! defined( 'GIVE_PLUGIN_URL' ) ) {
349
				define( 'GIVE_PLUGIN_URL', plugin_dir_url( __FILE__ ) );
350
			}
351
352
			// Plugin Basename aka: "give/give.php"
353
			if ( ! defined( 'GIVE_PLUGIN_BASENAME' ) ) {
354
				define( 'GIVE_PLUGIN_BASENAME', plugin_basename( __FILE__ ) );
355
			}
356
357
			// Plugin Root File
358
			if ( ! defined( 'GIVE_PLUGIN_FILE' ) ) {
359
				define( 'GIVE_PLUGIN_FILE', __FILE__ );
360
			}
361
362
			// Make sure CAL_GREGORIAN is defined
363
			if ( ! defined( 'CAL_GREGORIAN' ) ) {
364
				define( 'CAL_GREGORIAN', 1 );
365
			}
366
367
			// PHP version
368
			if ( ! defined( 'GIVE_REQUIRED_PHP_VERSION' ) ) {
369
				define( 'GIVE_REQUIRED_PHP_VERSION', '5.3' );
370
			}
371
		}
372
373
		/**
374
		 * Include required files
375
		 *
376
		 * @since  1.0
377
		 * @access private
378
		 *
379
		 * @return void
380
		 */
381
		private function includes() {
382
			global $give_options;
0 ignored issues
show
Compatibility Best Practice introduced by
Use of global functionality is not recommended; it makes your code harder to test, and less reusable.

Instead of relying on global state, we recommend one of these alternatives:

1. Pass all data via parameters

function myFunction($a, $b) {
    // Do something
}

2. Create a class that maintains your state

class MyClass {
    private $a;
    private $b;

    public function __construct($a, $b) {
        $this->a = $a;
        $this->b = $b;
    }

    public function myFunction() {
        // Do something
    }
}
Loading history...
383
384
			require_once GIVE_PLUGIN_DIR . 'includes/admin/class-admin-settings.php';
385
			require_once GIVE_PLUGIN_DIR . 'includes/admin/class-give-settings.php';
386
			$give_options = give_get_settings();
387
388
			require_once GIVE_PLUGIN_DIR . 'includes/admin/give-metabox-functions.php';
389
			require_once GIVE_PLUGIN_DIR . 'includes/class-give-cache.php';
390
			require_once GIVE_PLUGIN_DIR . 'includes/post-types.php';
391
			require_once GIVE_PLUGIN_DIR . 'includes/scripts.php';
392
			require_once GIVE_PLUGIN_DIR . 'includes/ajax-functions.php';
393
			require_once GIVE_PLUGIN_DIR . 'includes/actions.php';
394
			require_once GIVE_PLUGIN_DIR . 'includes/filters.php';
395
			require_once GIVE_PLUGIN_DIR . 'includes/api/class-give-api.php';
396
			require_once GIVE_PLUGIN_DIR . 'includes/class-give-tooltips.php';
397
			require_once GIVE_PLUGIN_DIR . 'includes/class-notices.php';
398
399
			require_once GIVE_PLUGIN_DIR . 'includes/class-give-roles.php';
400
			require_once GIVE_PLUGIN_DIR . 'includes/class-give-template-loader.php';
401
			require_once GIVE_PLUGIN_DIR . 'includes/class-give-donate-form.php';
402
			require_once GIVE_PLUGIN_DIR . 'includes/class-give-db.php';
403
			require_once GIVE_PLUGIN_DIR . 'includes/class-give-db-donors.php';
404
			require_once GIVE_PLUGIN_DIR . 'includes/class-give-db-donor-meta.php';
405
			require_once GIVE_PLUGIN_DIR . 'includes/class-give-donor.php';
406
			require_once GIVE_PLUGIN_DIR . 'includes/class-give-stats.php';
407
			require_once GIVE_PLUGIN_DIR . 'includes/class-give-session.php';
408
			require_once GIVE_PLUGIN_DIR . 'includes/class-give-html-elements.php';
409
			require_once GIVE_PLUGIN_DIR . 'includes/class-give-logging.php';
410
			require_once GIVE_PLUGIN_DIR . 'includes/class-give-license-handler.php';
411
			require_once GIVE_PLUGIN_DIR . 'includes/class-give-cron.php';
412
			require_once GIVE_PLUGIN_DIR . 'includes/class-give-email-access.php';
413
			require_once GIVE_PLUGIN_DIR . 'includes/class-give-db-payment-meta.php';
414
415
			require_once GIVE_PLUGIN_DIR . 'includes/country-functions.php';
416
			require_once GIVE_PLUGIN_DIR . 'includes/template-functions.php';
417
			require_once GIVE_PLUGIN_DIR . 'includes/misc-functions.php';
418
			require_once GIVE_PLUGIN_DIR . 'includes/forms/functions.php';
419
			require_once GIVE_PLUGIN_DIR . 'includes/forms/template.php';
420
			require_once GIVE_PLUGIN_DIR . 'includes/forms/widget.php';
421
			require_once GIVE_PLUGIN_DIR . 'includes/shortcodes.php';
422
			require_once GIVE_PLUGIN_DIR . 'includes/formatting.php';
423
			require_once GIVE_PLUGIN_DIR . 'includes/price-functions.php';
424
			require_once GIVE_PLUGIN_DIR . 'includes/error-tracking.php';
425
			require_once GIVE_PLUGIN_DIR . 'includes/process-donation.php';
426
			require_once GIVE_PLUGIN_DIR . 'includes/login-register.php';
427
			require_once GIVE_PLUGIN_DIR . 'includes/user-functions.php';
428
			require_once GIVE_PLUGIN_DIR . 'includes/plugin-compatibility.php';
429
			require_once GIVE_PLUGIN_DIR . 'includes/deprecated/deprecated-classes.php';
430
			require_once GIVE_PLUGIN_DIR . 'includes/deprecated/deprecated-functions.php';
431
			require_once GIVE_PLUGIN_DIR . 'includes/deprecated/deprecated-actions.php';
432
			require_once GIVE_PLUGIN_DIR . 'includes/deprecated/deprecated-filters.php';
433
434
			require_once GIVE_PLUGIN_DIR . 'includes/payments/backward-compatibility.php';
435
			require_once GIVE_PLUGIN_DIR . 'includes/payments/functions.php';
436
			require_once GIVE_PLUGIN_DIR . 'includes/payments/actions.php';
437
			require_once GIVE_PLUGIN_DIR . 'includes/payments/class-payment-stats.php';
438
			require_once GIVE_PLUGIN_DIR . 'includes/payments/class-payments-query.php';
439
			require_once GIVE_PLUGIN_DIR . 'includes/payments/class-give-payment.php';
440
441
			require_once GIVE_PLUGIN_DIR . 'includes/gateways/functions.php';
442
			require_once GIVE_PLUGIN_DIR . 'includes/gateways/actions.php';
443
			require_once GIVE_PLUGIN_DIR . 'includes/gateways/paypal-standard.php';
444
			require_once GIVE_PLUGIN_DIR . 'includes/gateways/offline-donations.php';
445
			require_once GIVE_PLUGIN_DIR . 'includes/gateways/manual.php';
446
447
			require_once GIVE_PLUGIN_DIR . 'includes/emails/class-give-emails.php';
448
			require_once GIVE_PLUGIN_DIR . 'includes/emails/class-give-email-tags.php';
449
			require_once GIVE_PLUGIN_DIR . 'includes/admin/emails/class-email-notifications.php';
450
			require_once GIVE_PLUGIN_DIR . 'includes/emails/functions.php';
451
			require_once GIVE_PLUGIN_DIR . 'includes/emails/template.php';
452
			require_once GIVE_PLUGIN_DIR . 'includes/emails/actions.php';
453
454
			if ( defined( 'WP_CLI' ) && WP_CLI ) {
455
				require_once GIVE_PLUGIN_DIR . 'includes/class-give-cli-commands.php';
456
			}
457
458
			if ( is_admin() || ( defined( 'WP_CLI' ) && WP_CLI ) ) {
459
460
				require_once GIVE_PLUGIN_DIR . 'includes/admin/admin-footer.php';
461
				require_once GIVE_PLUGIN_DIR . 'includes/admin/welcome.php';
462
				require_once GIVE_PLUGIN_DIR . 'includes/admin/admin-pages.php';
463
				require_once GIVE_PLUGIN_DIR . 'includes/admin/class-api-keys-table.php';
464
				require_once GIVE_PLUGIN_DIR . 'includes/admin/class-i18n-module.php';
465
				require_once GIVE_PLUGIN_DIR . 'includes/admin/admin-actions.php';
466
				require_once GIVE_PLUGIN_DIR . 'includes/admin/admin-filters.php';
467
				require_once GIVE_PLUGIN_DIR . 'includes/admin/system-info.php';
468
				require_once GIVE_PLUGIN_DIR . 'includes/admin/add-ons.php';
469
				require_once GIVE_PLUGIN_DIR . 'includes/admin/plugins.php';
470
				require_once GIVE_PLUGIN_DIR . 'includes/admin/dashboard-widgets.php';
471
472
				require_once GIVE_PLUGIN_DIR . 'includes/admin/payments/actions.php';
473
				require_once GIVE_PLUGIN_DIR . 'includes/admin/payments/payments-history.php';
474
475
				require_once GIVE_PLUGIN_DIR . 'includes/admin/donors/donors.php';
476
				require_once GIVE_PLUGIN_DIR . 'includes/admin/donors/donor-functions.php';
477
				require_once GIVE_PLUGIN_DIR . 'includes/admin/donors/donor-actions.php';
478
479
				require_once GIVE_PLUGIN_DIR . 'includes/admin/forms/metabox.php';
480
				require_once GIVE_PLUGIN_DIR . 'includes/admin/forms/class-metabox-form-data.php';
481
				require_once GIVE_PLUGIN_DIR . 'includes/admin/forms/dashboard-columns.php';
482
483
				require_once GIVE_PLUGIN_DIR . 'includes/admin/tools/export/export-functions.php';
484
				require_once GIVE_PLUGIN_DIR . 'includes/admin/tools/export/class-export.php';
485
				require_once GIVE_PLUGIN_DIR . 'includes/admin/tools/export/export-actions.php';
486
				require_once GIVE_PLUGIN_DIR . 'includes/admin/tools/export/pdf-reports.php';
487
488
				require_once GIVE_PLUGIN_DIR . 'includes/admin/reporting/reports.php';
489
				require_once GIVE_PLUGIN_DIR . 'includes/admin/reporting/class-give-graph.php';
490
				require_once GIVE_PLUGIN_DIR . 'includes/admin/reporting/graphing.php';
491
492
				require_once GIVE_PLUGIN_DIR . 'includes/admin/tools/data/tools-actions.php';
493
494
				require_once GIVE_PLUGIN_DIR . 'includes/admin/shortcodes/abstract-shortcode-generator.php';
495
				require_once GIVE_PLUGIN_DIR . 'includes/admin/shortcodes/class-shortcode-button.php';
496
				require_once GIVE_PLUGIN_DIR . 'includes/admin/shortcodes/shortcode-give-form.php';
497
				require_once GIVE_PLUGIN_DIR . 'includes/admin/shortcodes/shortcode-give-goal.php';
498
				require_once GIVE_PLUGIN_DIR . 'includes/admin/shortcodes/shortcode-give-login.php';
499
				require_once GIVE_PLUGIN_DIR . 'includes/admin/shortcodes/shortcode-give-register.php';
500
				require_once GIVE_PLUGIN_DIR . 'includes/admin/shortcodes/shortcode-give-profile-editor.php';
501
				require_once GIVE_PLUGIN_DIR . 'includes/admin/shortcodes/shortcode-give-donation-history.php';
502
				require_once GIVE_PLUGIN_DIR . 'includes/admin/shortcodes/shortcode-give-receipt.php';
503
504
				require_once GIVE_PLUGIN_DIR . 'includes/admin/upgrades/upgrade-functions.php';
505
				require_once GIVE_PLUGIN_DIR . 'includes/admin/upgrades/upgrades.php';
506
507
			}// End if().
0 ignored issues
show
Unused Code Comprehensibility introduced by
43% of this comment could be valid code. Did you maybe forget this after debugging?

Sometimes obsolete code just ends up commented out instead of removed. In this case it is better to remove the code once you have checked you do not need it.

The code might also have been commented out for debugging purposes. In this case it is vital that someone uncomments it again or your project may behave in very unexpected ways in production.

This check looks for comments that seem to be mostly valid code and reports them.

Loading history...
508
509
			require_once GIVE_PLUGIN_DIR . 'includes/install.php';
510
511
		}
512
513
		/**
514
		 * Loads the plugin language files.
515
		 *
516
		 * @since  1.0
517
		 * @access public
518
		 *
519
		 * @return void
520
		 */
521
		public function load_textdomain() {
522
523
			// Set filter for Give's languages directory
524
			$give_lang_dir = dirname( plugin_basename( GIVE_PLUGIN_FILE ) ) . '/languages/';
525
			$give_lang_dir = apply_filters( 'give_languages_directory', $give_lang_dir );
526
527
			// Traditional WordPress plugin locale filter.
528
			$locale = is_admin() && function_exists( 'get_user_locale' ) ? get_user_locale() : get_locale();
529
			$locale = apply_filters( 'plugin_locale', $locale, 'give' );
530
531
			unload_textdomain( 'give' );
532
			load_textdomain( 'give', WP_LANG_DIR . '/give/give-' . $locale . '.mo' );
533
			load_plugin_textdomain( 'give', false, $give_lang_dir );
534
535
		}
536
537
	}
538
539
endif; // End if class_exists check
540
541
542
/**
543
 * Start Give
544
 *
545
 * The main function responsible for returning the one true Give instance to functions everywhere.
546
 *
547
 * Use this function like you would a global variable, except without needing
548
 * to declare the global.
549
 *
550
 * Example: <?php $give = Give(); ?>
551
 *
552
 * @since 1.0
553
 * @return object|Give
554
 */
555
function Give() {
556
	return Give::instance();
557
}
558
559
Give();
560