From 7b02207537d35bfa1714bf8beafc921f717d100a Mon Sep 17 00:00:00 2001
From: 单军华
Date: Wed, 11 Jul 2018 10:47:42 +0800
Subject: [PATCH] 首次上传

---
 screendisplay/Pods/YYCategories/YYCategories/Foundation/NSArray+YYAdd.h |  196 +++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 196 insertions(+), 0 deletions(-)

diff --git a/screendisplay/Pods/YYCategories/YYCategories/Foundation/NSArray+YYAdd.h b/screendisplay/Pods/YYCategories/YYCategories/Foundation/NSArray+YYAdd.h
new file mode 100755
index 0000000..44af305
--- /dev/null
+++ b/screendisplay/Pods/YYCategories/YYCategories/Foundation/NSArray+YYAdd.h
@@ -0,0 +1,196 @@
+//
+//  NSArray+YYAdd.h
+//  YYCategories <https://github.com/ibireme/YYCategories>
+//
+//  Created by ibireme on 13/4/4.
+//  Copyright (c) 2015 ibireme.
+//
+//  This source code is licensed under the MIT-style license found in the
+//  LICENSE file in the root directory of this source tree.
+//
+
+#import <Foundation/Foundation.h>
+
+NS_ASSUME_NONNULL_BEGIN
+
+/**
+ Provide some some common method for `NSArray`.
+ */
+@interface NSArray (YYAdd)
+
+/**
+ Creates and returns an array from a specified property list data.
+ 
+ @param plist   A property list data whose root object is an array.
+ @return A new array created from the plist data, or nil if an error occurs.
+ */
++ (nullable NSArray *)arrayWithPlistData:(NSData *)plist;
+
+/**
+ Creates and returns an array from a specified property list xml string.
+ 
+ @param plist   A property list xml string whose root object is an array.
+ @return A new array created from the plist string, or nil if an error occurs.
+ */
++ (nullable NSArray *)arrayWithPlistString:(NSString *)plist;
+
+/**
+ Serialize the array to a binary property list data.
+ 
+ @return A bplist data, or nil if an error occurs.
+ */
+- (nullable NSData *)plistData;
+
+/**
+ Serialize the array to a xml property list string.
+ 
+ @return A plist xml string, or nil if an error occurs.
+ */
+- (nullable NSString *)plistString;
+
+/**
+ Returns the object located at a random index.
+ 
+ @return The object in the array with a random index value.
+ If the array is empty, returns nil.
+ */
+- (nullable id)randomObject;
+
+/**
+ Returns the object located at index, or return nil when out of bounds.
+ It's similar to `objectAtIndex:`, but it never throw exception.
+ 
+ @param index The object located at index.
+ */
+- (nullable id)objectOrNilAtIndex:(NSUInteger)index;
+
+/**
+ Convert object to json string. return nil if an error occurs.
+ NSString/NSNumber/NSDictionary/NSArray
+ */
+- (nullable NSString *)jsonStringEncoded;
+
+/**
+ Convert object to json string formatted. return nil if an error occurs.
+ */
+- (nullable NSString *)jsonPrettyStringEncoded;
+
+@end
+
+
+/**
+ Provide some some common method for `NSMutableArray`.
+ */
+@interface NSMutableArray (YYAdd)
+
+/**
+ Creates and returns an array from a specified property list data.
+ 
+ @param plist   A property list data whose root object is an array.
+ @return A new array created from the plist data, or nil if an error occurs.
+ */
++ (nullable NSMutableArray *)arrayWithPlistData:(NSData *)plist;
+
+/**
+ Creates and returns an array from a specified property list xml string.
+ 
+ @param plist   A property list xml string whose root object is an array.
+ @return A new array created from the plist string, or nil if an error occurs.
+ */
++ (nullable NSMutableArray *)arrayWithPlistString:(NSString *)plist;
+
+/**
+ Removes the object with the lowest-valued index in the array.
+ If the array is empty, this method has no effect.
+ 
+ @discussion Apple has implemented this method, but did not make it public.
+ Override for safe.
+ */
+- (void)removeFirstObject;
+
+/**
+ Removes the object with the highest-valued index in the array.
+ If the array is empty, this method has no effect.
+ 
+ @discussion Apple's implementation said it raises an NSRangeException if the
+ array is empty, but in fact nothing will happen. Override for safe.
+ */
+- (void)removeLastObject;
+
+/**
+ Removes and returns the object with the lowest-valued index in the array.
+ If the array is empty, it just returns nil.
+ 
+ @return The first object, or nil.
+ */
+- (nullable id)popFirstObject;
+
+/**
+ Removes and returns the object with the highest-valued index in the array.
+ If the array is empty, it just returns nil.
+ 
+ @return The first object, or nil.
+ */
+- (nullable id)popLastObject;
+
+/**
+ Inserts a given object at the end of the array.
+ 
+ @param anObject The object to add to the end of the array's content.
+ This value must not be nil. Raises an NSInvalidArgumentException if anObject is nil.
+ */
+- (void)appendObject:(id)anObject;
+
+/**
+ Inserts a given object at the beginning of the array.
+ 
+ @param anObject The object to add to the end of the array's content.
+ This value must not be nil. Raises an NSInvalidArgumentException if anObject is nil.
+ */
+- (void)prependObject:(id)anObject;
+
+/**
+ Adds the objects contained in another given array to the end of the receiving
+ array's content.
+ 
+ @param objects An array of objects to add to the end of the receiving array's
+ content. If the objects is empty or nil, this method has no effect.
+ */
+- (void)appendObjects:(NSArray *)objects;
+
+/**
+ Adds the objects contained in another given array to the beginnin of the receiving
+ array's content.
+ 
+ @param objects An array of objects to add to the beginning of the receiving array's
+ content. If the objects is empty or nil, this method has no effect.
+ */
+- (void)prependObjects:(NSArray *)objects;
+
+/**
+ Adds the objects contained in another given array at the index of the receiving
+ array's content.
+ 
+ @param objects An array of objects to add to the receiving array's
+ content. If the objects is empty or nil, this method has no effect.
+ 
+ @param index The index in the array at which to insert objects. This value must
+ not be greater than the count of elements in the array. Raises an
+ NSRangeException if index is greater than the number of elements in the array.
+ */
+- (void)insertObjects:(NSArray *)objects atIndex:(NSUInteger)index;
+
+/**
+ Reverse the index of object in this array.
+ Example: Before @[ @1, @2, @3 ], After @[ @3, @2, @1 ].
+ */
+- (void)reverse;
+
+/**
+ Sort the object in this array randomly.
+ */
+- (void)shuffle;
+
+@end
+
+NS_ASSUME_NONNULL_END

--
Gitblit v1.8.0