Всем привет! 👋 Хочу поделиться забавной историей.
Недавно собрал фидбэк по приложению для артиклей у знакомых. Одно из предложений было подсвечивать слова в предложениях.
Для этого исходное предложение нужно разбить на слова, и что самое главное найти это слово вместе с артиклем. Осложняется это тем, что в зависимости от падежа и рода существительного, артикль может меняться.
Так вот пообщавшись с моим другом с утреца📱 получил от него идею воспользоваться spaCy - Python библиотека для NLP (Обработка естественного языка). Инструмент действительно хороший, но не без ошибок.
А вечером я пошёл на мини-конференцию по Python👩💻
Расписание я подробно посмотрел буквально перед входом - и был приятно удивлён, т.к. первый же докладчик была CEO из компании, которая занимается разработкой spaCy.
Я просто не мог уйти без их стикер🔥
Недавно собрал фидбэк по приложению для артиклей у знакомых. Одно из предложений было подсвечивать слова в предложениях.
Для этого исходное предложение нужно разбить на слова, и что самое главное найти это слово вместе с артиклем. Осложняется это тем, что в зависимости от падежа и рода существительного, артикль может меняться.
Так вот пообщавшись с моим другом с утреца
А вечером я пошёл на мини-конференцию по Python
Расписание я подробно посмотрел буквально перед входом - и был приятно удивлён, т.к. первый же докладчик была CEO из компании, которая занимается разработкой spaCy.
Я просто не мог уйти без их стикер
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥1😁1
Сегодня смотрел как правильно вносить изменения в модели CoreData.
В текущей модели у меня предложения представлены массивом, который хранится в Core Data напрямую.
Переделал так, что каждое предложение представляет собой набор токенов (слово или знак препинания) и индексы токенов, которые нужно будет подсветить.
Наивным путём удалил одно поле и добавил другое😮
В симуляторе и на телефоне отработало идеально. Но вот с preview всё сломалось. Ни перезагрузка, ни очистка рабочих директорий - ничего не помогало.
🚫 Ошибка была вида: Persistent store migration failed, missing mapping model
Ну и насколько я понял, нужно было создать новую версию модели. Сделал так. Получается в проекте теперь хранятся обе модели.
Сейчас всё снова работает как часы! ⏰
В текущей модели у меня предложения представлены массивом, который хранится в Core Data напрямую.
Переделал так, что каждое предложение представляет собой набор токенов (слово или знак препинания) и индексы токенов, которые нужно будет подсветить.
Наивным путём удалил одно поле и добавил другое
В симуляторе и на телефоне отработало идеально. Но вот с preview всё сломалось. Ни перезагрузка, ни очистка рабочих директорий - ничего не помогало.
Ну и насколько я понял, нужно было создать новую версию модели. Сделал так. Получается в проекте теперь хранятся обе модели.
Сейчас всё снова работает как часы! ⏰
Please open Telegram to view this post
VIEW IN TELEGRAM
👍1
Please open Telegram to view this post
VIEW IN TELEGRAM
Вау 😯 Рассказывает дочка Пола из hackingwithswift про неочевидные вещи в swift (не сложные, но забавные), ей всего 15, а уже на сцене. Невероятный буст мотивации!
https://www.youtube.com/watch?v=dQJUoNIbDsg
Как быстро растут чужие дети 🥲
https://www.youtube.com/watch?v=dQJUoNIbDsg
Как быстро растут чужие дети 🥲
Please open Telegram to view this post
VIEW IN TELEGRAM
YouTube
Swift WTF – Surprising behaviors while learning Swift
Swift is a smart, modern programming language that makes it easy to build a wide range of software, but if you're not careful it's easy to run into some surprising behaviors. In this video you'll learn about a few of them, and I'm pretty sure everyone will…
Когда опыт не спасает от неуверенности
Будучи синьёром 🍅 backend разработчиком, я привык понимать, почему код устроен так или иначе. Привык сразу закладывать масштабируемость, отказоустойчивость, где нужно, думать о поддержке и развитии проекта.
Сейчас я изучаю iOS и SwiftUI. Почти каждый шаг сопровождает меня сомнениями.
Управление состоянием, архитектура, тестирование, переходы и способы навигации - всё непривычно. Да, код работает, приложение запускается. Но внутри постоянное ощущение, что я делаю что-то не так, не по принятым стандартам, что-то упускаю, где-то закладываю потенциальные проблемы.
Несмотря на то, что ловлю себя на мысли, что так и должно быть, это неприятное ощущение сопровождает меня. Конечно, это нормально, будучи в начале пути совершать ошибки. Да даже и где-то посреди, это тоже неизбежно. Осознаю, понимаю, но бороться с этим не так уж просто.
Ну хватит ныть! Главное - продолжаем, с выводами по пути (и неприятными тоже), но движемся вперед!
Возможно среди вас есть те, кто прошел через это, и, естественно, те, кто только будет проходить. Не забываем, что это временно💪
Будучи синьёром 🍅 backend разработчиком, я привык понимать, почему код устроен так или иначе. Привык сразу закладывать масштабируемость, отказоустойчивость, где нужно, думать о поддержке и развитии проекта.
Сейчас я изучаю iOS и SwiftUI. Почти каждый шаг сопровождает меня сомнениями.
Управление состоянием, архитектура, тестирование, переходы и способы навигации - всё непривычно. Да, код работает, приложение запускается. Но внутри постоянное ощущение, что я делаю что-то не так, не по принятым стандартам, что-то упускаю, где-то закладываю потенциальные проблемы.
Несмотря на то, что ловлю себя на мысли, что так и должно быть, это неприятное ощущение сопровождает меня. Конечно, это нормально, будучи в начале пути совершать ошибки. Да даже и где-то посреди, это тоже неизбежно. Осознаю, понимаю, но бороться с этим не так уж просто.
Ну хватит ныть! Главное - продолжаем, с выводами по пути (и неприятными тоже), но движемся вперед!
Возможно среди вас есть те, кто прошел через это, и, естественно, те, кто только будет проходить. Не забываем, что это временно
Please open Telegram to view this post
VIEW IN TELEGRAM
👍1
Немного о прогрессе и успехах
Получил позитивный фидбэк, с элементами критики и предложений по улучшению от преподавателя немецкого языка.
У меня двоякое ощущение, т.к. одно из названных достоинств было - простота, а новые фичи такие, что сильно усложнят интерфейс. Как быть дальше🤔
➖ ➖ ➖
Пока в голове я ношу и перевариваю идею как будет выглядеть приложение - трекер товаров. То как я хочу его видеть, понимаю, что технически будет очень сложно реализовать. Моего опыта явно не хватит. А из предыдущего поста, как вы могли заметить, я хочу сделать всё относительно правильно 😁
Получил позитивный фидбэк, с элементами критики и предложений по улучшению от преподавателя немецкого языка.
У меня двоякое ощущение, т.к. одно из названных достоинств было - простота, а новые фичи такие, что сильно усложнят интерфейс. Как быть дальше
Пока в голове я ношу и перевариваю идею как будет выглядеть приложение - трекер товаров. То как я хочу его видеть, понимаю, что технически будет очень сложно реализовать. Моего опыта явно не хватит. А из предыдущего поста, как вы могли заметить, я хочу сделать всё относительно правильно 😁
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥1
Мультиэкран без навигации
Обнаружил интересный подход к построению приложения с несколькими экранами, но без навигации.
Выглядит очень удобно для небольших приложений, где всю логику можно уместить в стейт машину.
Основная идея - иметь одно вью, которое меняет своё отображение в зависимости от текущего состояния.
😎 На счет перформанса не уверен, но для квиз подобных приложений удобно!
Обнаружил интересный подход к построению приложения с несколькими экранами, но без навигации.
Выглядит очень удобно для небольших приложений, где всю логику можно уместить в стейт машину.
Основная идея - иметь одно вью, которое меняет своё отображение в зависимости от текущего состояния.
struct WordsGameView: View {
@StateObject private var viewModel = WordsGameViewModel()
var body: some View {
ZStack {
switch viewModel.currentScreen {
case .welcome:
WelcomeView {
viewModel.startQuiz()
}
case .question(let question):
QuestionView(question: question) { answer in
viewModel.submit(answer: answer)
}
case .result(let result):
ResultView(result: result) {
viewModel.goToMainMenu()
}
case .mainMenu:
MainMenuView {
viewModel.startQuiz()
}
}
}
.animation(.none, value: viewModel.currentScreen)
}
}
Please open Telegram to view this post
VIEW IN TELEGRAM
👍1
Вау, обновление Xcode сломало билд. Возможно, у меня что-то с настройками не так, но до обновления билд работал!
Пока не пойму как это пофиксить, но запуск на устройстве так же не работает.
Обновлялся с надеждой, что Preview Canvas пофиксили. До этого он сбрасывал свой размер до половины экрана, что жутко неудобно.
Пока не пойму как это пофиксить, но запуск на устройстве так же не работает.
Обновлялся с надеждой, что Preview Canvas пофиксили. До этого он сбрасывал свой размер до половины экрана, что жутко неудобно.
😢1
Дорабатываю дизайн отображения слов.
1. Уровень изученности слова
2. Просмотр подробной информации по слову
Всё делается по фидбэку пользователей❤️ ❤️ ❤️
1. Уровень изученности слова
2. Просмотр подробной информации по слову
Всё делается по фидбэку пользователей
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
❤1
Как мне рекомендовали в комментариях, я затрагиваю Firebase 🔥 (да, логотип у них уже сменился).
Решил посмотреть как работает инициализация в Objective-C проектах… Осмелюсь сказать, что я знаю базовый C, но что это???😮
После прочтения этого, я слышу зов Ктулху🙉
Решил посмотреть как работает инициализация в Objective-C проектах… Осмелюсь сказать, что я знаю базовый C, но что это???
После прочтения этого, я слышу зов Ктулху🙉
Please open Telegram to view this post
VIEW IN TELEGRAM
😁1
Что за прикол от Google? Они документируют iOS лучше, чем свой Android? 🤨
Или на Android настолько суровые ребята, что A/B тесты им не нужны?
Или на Android настолько суровые ребята, что A/B тесты им не нужны?
Please open Telegram to view this post
VIEW IN TELEGRAM
🤔1
За прошедшие 2 вечера мне удалось реализовать:
🔸 Загрузку данных в Firestore Database
🔸 Скачивание обновленных записей в app
Как результат, не нужно ждать ревью (порой это занимает 2-3 дня), а просто обновлять контент приложения.
Дальше посмотрим на эти 2 майлстоуна чуть ближе. Совсем чуть-чуть🙈
Как результат, не нужно ждать ревью (порой это занимает 2-3 дня), а просто обновлять контент приложения.
Дальше посмотрим на эти 2 майлстоуна чуть ближе. Совсем чуть-чуть
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥3
Загрузка данных в Firestore Database
Firebase предоставляет крутое SDK, как минимум для простых вещей оно подходит безупречно! На мой взгляд, таким и должно быть SDK - работает при минимальной конфигурации.
Python скрипт для загрузки документов. Схема создаётся на основе json объекта, который хранится в переменной
creds.json - скачивается с Firebase Console.
Обожаю Python👩💻 за его простоту и лаконичность 🟥
Firebase предоставляет крутое SDK, как минимум для простых вещей оно подходит безупречно! На мой взгляд, таким и должно быть SDK - работает при минимальной конфигурации.
Python скрипт для загрузки документов. Схема создаётся на основе json объекта, который хранится в переменной
word
.creds.json - скачивается с Firebase Console.
# Некоторые части я специально исключил для краткости.
from google.cloud import firestore
os.environ["GOOGLE_APPLICATION_CREDENTIALS"] = “path/creds.json”
db = firestore.Client()
with open(json_file_path, "r", encoding="utf-8") as f:
words = json.load(f)
for word in words:
# небольшая настройка word, чтобы привести некоторые поля к определенным типам
db.collection("words").document(doc_id).set(word)
Обожаю Python
Please open Telegram to view this post
VIEW IN TELEGRAM
❤1
Скачивание обновленных записей в app
SDK для iOS так же порадовало!
Для начала добавил в зависимости Firebase SDK, затем скачал файл с кредами
Дальше создал сервис, инкапсулирующий работу с Firestore:
Как я работаю с этим классом?
1️⃣ Переодически вызываю
2️⃣ Проверяю настало ли время идти в Firestore
3️⃣ Если да, то нахожу максимальное значение
4️⃣ Последним шагом иду в Firestore за обновленными записями
Это позволяет уменьшить нагрузку на базу (там есть лимиты).
Пока не посмотрел детально, но вроде можно не делать polling, а подписываться на обновления в Firestore. Возможно мне это и не нужно.
SDK для iOS так же порадовало!
Для начала добавил в зависимости Firebase SDK, затем скачал файл с кредами
GoogleService-Info.plist
, и в основном классе App добавил делегат, вызывающийFirebaseApp.configure()
. Всё! Настроено…Дальше создал сервис, инкапсулирующий работу с Firestore:
class FirebaseWordSyncService {
private let db = Firestore.firestore()
func fetchUpdatedWords(since lastUpdated: Date, completion: @escaping ([Word]) -> Void) {
print("Fetching words updated since \(lastUpdated)")
db.collection(collection)
.whereField("lastUpdated", isGreaterThan: lastUpdated)
.getDocuments { snapshot, error in
// handle docs
}
}
}
Как я работаю с этим классом?
fetchUpdatedWords
из приложенияlastUpdated
в базе Core DataЭто позволяет уменьшить нагрузку на базу (там есть лимиты).
Пока не посмотрел детально, но вроде можно не делать polling, а подписываться на обновления в Firestore. Возможно мне это и не нужно.
Please open Telegram to view this post
VIEW IN TELEGRAM
👍1
Тема с Firebase была предложена какое-то время назад одним из читателей. Если тебе хочется повлиять на контент этого канала - это возможно, я открыт к идеям 😇
Please open Telegram to view this post
VIEW IN TELEGRAM
Натолкнулся на байтклик статью на Medium
SwiftUI in 2025: Forget MVVM: https://dimillian.medium.com/swiftui-in-2025-forget-mvvm-262ff2bbd2ed
В ней рассказывается материал на основе доклада с wwdc 2019 😄
Сам доклад супер!🔥
https://developer.apple.com/videos/play/wwdc2019/226
Рассказывают про основную концепцию SwiftUI: View это функция от данных. Думаю, попробую в дальнейшем этот подход. Но переписывать готовое не буду😵💫
И еще упомянутые в статье (но их еще не посмотрел):
https://developer.apple.com/videos/play/wwdc2023/10149/
https://developer.apple.com/videos/play/wwdc2020/10040/
SwiftUI in 2025: Forget MVVM: https://dimillian.medium.com/swiftui-in-2025-forget-mvvm-262ff2bbd2ed
В ней рассказывается материал на основе доклада с wwdc 2019 😄
Сам доклад супер!
https://developer.apple.com/videos/play/wwdc2019/226
Рассказывают про основную концепцию SwiftUI: View это функция от данных. Думаю, попробую в дальнейшем этот подход. Но переписывать готовое не буду
И еще упомянутые в статье (но их еще не посмотрел):
https://developer.apple.com/videos/play/wwdc2023/10149/
https://developer.apple.com/videos/play/wwdc2020/10040/
Please open Telegram to view this post
VIEW IN TELEGRAM
👍1
Сегодня у меня знатно пригорело 🧨
Сижу я радостный, жду ревью версии с интеграцией с Firebase. Проверил на различных симуляторах, на физическом устройстве. Приходит реджект… 🙅♂️
Иду разбираться в чем дело. Они сообщили, что не работает на iPad Air (5th generation) - закрашилось при запуске. Приложили логи и инструкции как анализировать проблему. Запускаю симулятор локально… работает.
Начинаю смотреть логи👀 которые они прислали. Там при старте приложения что-то сломалось, но что не понятно! Указывает в трейсе имя моего приложения, а вместо названий методов просто адреса с какими-то сдвигами.
Порылся в интернете, ссылках что ревьюеры дали, у гпт поспрашивал, говорят нужен dSYM - в нем хранится информация для дебага, как раз сопоставление между адресами и названиями методов. Положил в рабочую директорию Xcode, результата нет. Добавил архив билда, скачав его из Xcode Cloud предварительно. То же самое…🤬
Загружаю в TestFlight пересобранную версию и буду смотреть в чем причина. Очень жаль, что воспроизвести не удалось. Ту зафейленную версию не смог через Internal Testing TestFlight проверить, т.к. интеграция сломалась и мне просто не дали потестировать тот билд.
Пока заметил через😮 ). Может каких-то полей при старте не было видно из-за этого…
На всякий случай, заменил имена моделей на что-то содержащее v1, v2, v3, …
Сижу я радостный, жду ревью версии с интеграцией с Firebase. Проверил на различных симуляторах, на физическом устройстве. Приходит реджект… 🙅♂️
Иду разбираться в чем дело. Они сообщили, что не работает на iPad Air (5th generation) - закрашилось при запуске. Приложили логи и инструкции как анализировать проблему. Запускаю симулятор локально… работает.
Начинаю смотреть логи
13 DerDieDas DE 0x102859e7c 0x102830000 + 171644
14 DerDieDas DE 0x102858a70 0x102830000 + 166512
15 SwiftUI 0x19d23eec0 static App.main() + 164
Порылся в интернете, ссылках что ревьюеры дали, у гпт поспрашивал, говорят нужен dSYM - в нем хранится информация для дебага, как раз сопоставление между адресами и названиями методов. Положил в рабочую директорию Xcode, результата нет. Добавил архив билда, скачав его из Xcode Cloud предварительно. То же самое…
Загружаю в TestFlight пересобранную версию и буду смотреть в чем причина. Очень жаль, что воспроизвести не удалось. Ту зафейленную версию не смог через Internal Testing TestFlight проверить, т.к. интеграция сломалась и мне просто не дали потестировать тот билд.
Пока заметил через
git status
, что Xcode менял активную Core Data модель на предыдущую версию (с чего бы вообще На всякий случай, заменил имена моделей на что-то содержащее v1, v2, v3, …
Please open Telegram to view this post
VIEW IN TELEGRAM
🤬1
Заметил следующую штуку
Краш репорты представлены файлами с расширением ips. Если открыть их в VS Code, то они выглядят как json. Но если открыть их с помощью Console (на скриншоте) или Xcode, то открывается отформатированный трейс по потокам, с заголовком (как на 2ой картинке).
Адреса там не найти, т.к. они представлены чуть в другом формате. Но суть в том, что json преобразуется в форматированный и более понятный человеку (пока не мне 🙈) вид.
Но в итоге я так и не понял, как заставить их сматчить адреса и дебаг информацию. Пробовал так же консольные инструменты, но не сработало.
Ужасное ощущение осталось, но я постараюсь на нем не зацикливаться. Ведь упало не у любимых пользователей🟥 🟥
Краш репорты представлены файлами с расширением ips. Если открыть их в VS Code, то они выглядят как json. Но если открыть их с помощью Console (на скриншоте) или Xcode, то открывается отформатированный трейс по потокам, с заголовком (как на 2ой картинке).
Адреса там не найти, т.к. они представлены чуть в другом формате. Но суть в том, что json преобразуется в форматированный и более понятный человеку (пока не мне 🙈) вид.
Но в итоге я так и не понял, как заставить их сматчить адреса и дебаг информацию. Пробовал так же консольные инструменты, но не сработало.
Ужасное ощущение осталось, но я постараюсь на нем не зацикливаться. Ведь упало не у любимых пользователей
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM