Как использовать SCNetworkReachability в Swift
Я пытаюсь конвертироватьэтот фрагмент кода для Swift. Я изо всех сил пытаюсь оторваться от земли из-за некоторых трудностей.
- (BOOL) connectedToNetwork
{
// Create zero addy
struct sockaddr_in zeroAddress;
bzero(&zeroAddress, sizeof(zeroAddress));
zeroAddress.sin_len = sizeof(zeroAddress);
zeroAddress.sin_family = AF_INET;
// Recover reachability flags
SCNetworkReachabilityRef defaultRouteReachability = SCNetworkReachabilityCreateWithAddress(NULL, (struct sockaddr *)&zeroAddress);
SCNetworkReachabilityFlags flags;
BOOL didRetrieveFlags = SCNetworkReachabilityGetFlags(defaultRouteReachability, &flags);
CFRelease(defaultRouteReachability);
if (!didRetrieveFlags)
{
return NO;
}
BOOL isReachable = flags & kSCNetworkFlagsReachable;
BOOL needsConnection = flags & kSCNetworkFlagsConnectionRequired;
return (isReachable && !needsConnection) ? YES : NO;
}
Первый и главный вопрос, который у меня возникает, заключается в том, как определить и работать со структурами Си. В первой строке (struct sockaddr_in zeroAddress;
) приведенного выше кода, я думаю, что они определяют экземпляр под названиемzeroAddress
я полагаю, из структуры sockaddr_in (?) Я пытался объявитьvar
как это.
var zeroAddress = sockaddr_in()
Но я получаю ошибкуОтсутствует аргумент для параметра 'sin_len' в вызове что понятно, потому что эта структура принимает ряд аргументов. Поэтому я попробовал еще раз.
var zeroAddress = sockaddr_in(sin_len: sizeof(zeroAddress), sin_family: AF_INET, sin_port: nil, sin_addr: nil, sin_zero: nil)
Как и ожидалось, я получаю другую ошибкуПеременная, используемая в пределах своего начального значения, Я тоже понимаю причину этой ошибки. В C они сначала объявляют экземпляр, а затем заполняют параметры. Насколько я знаю, в Свифте это невозможно. Так что я действительно потерял в этом вопросе, что делать.
Я читаю официальный Appleдокумент о взаимодействии с C API в Swift, но у него нет примеров работы со структурами.
Может кто-нибудь помочь мне здесь? Я действительно ценю это.
Спасибо.
ОБНОВИТЬ: Благодаря Мартину я смог преодолеть начальную проблему. Но Свифт не облегчает мне задачу. Я получаю несколько новых ошибок.
func connectedToNetwork() -> Bool {
var zeroAddress = sockaddr_in(sin_len: 0, sin_family: 0, sin_port: 0, sin_addr: in_addr(s_addr: 0), sin_zero: (0, 0, 0, 0, 0, 0, 0, 0))
zeroAddress.sin_len = UInt8(sizeofValue(zeroAddress))
zeroAddress.sin_family = sa_family_t(AF_INET)
var defaultRouteReachability: SCNetworkReachabilityRef = SCNetworkReachabilityCreateWithAddress(UnsafePointer<Void>, UnsafePointer<zeroAddress>) // 'zeroAddress' is not a type
var flags = SCNetworkReachabilityFlags()
let didRetrieveFlags = SCNetworkReachabilityGetFlags(defaultRouteReachability, UnsafeMutablePointer<flags>) // 'flags' is not a type
defaultRouteReachability.dealloc(1) // 'SCNetworkReachabilityRef' does not have a member named 'dealloc'
if didRetrieveFlags == false {
return false
}
let isReachable: Bool = flags & kSCNetworkFlagsReachable // Cannot invoke '&' with an argument list of type '(@lvalue UInt32, Int)'
let needsConnection: Bool = flags & kSCNetworkFlagsConnectionRequired // Cannot invoke '&' with an argument list of type '(@lvalue UInt32, Int)'
return (isReachable && !needsConnection) ? true : false
}
РЕДАКТИРОВАТЬ 1: Хорошо, я изменил эту строку на это,
var defaultRouteReachability: SCNetworkReachabilityRef = SCNetworkReachabilityCreateWithAddress(UnsafePointer<Void>(), &zeroAddress)
Новая ошибка, которую я получаю в этой строке:«UnsafePointer» не конвертируется в «CFAllocator», Как вам пройтиNULL
в Свифте?
Также я изменил эту строку, и ошибка исчезла.
let didRetrieveFlags = SCNetworkReachabilityGetFlags(defaultRouteReachability, &flags)
РЕДАКТИРОВАТЬ 2: Я прошелnil
в этой строке, увидевэтот вопрос. Но этот ответ противоречит ответуВот, Он говорит, что нет эквивалентаNULL
в Свифте.
var defaultRouteReachability: SCNetworkReachabilityRef = SCNetworkReachabilityCreateWithAddress(nil, &zeroAddress)
В любом случае я получаю новую ошибку, говоря«sockaddr_in» не идентичен «sockaddr» на вышеуказанной линии.