Чтение онлайн

на главную - закладки

Жанры

Основы программирования в Linux
Шрифт:

 (void)fgets(tmp_str, TMP_STRING_LEN, stdin);

 strip_return(tmp_str);

 strncpy(new_entry.artist, tmp_str, CAT_ARTIST_LEN - 1);

 printf("\nNew catalog entry entry is :-\n");

 display_cdc(&new_entry);

 if (get_confirm("Add this entry ? ")) {

memcpy(entry_to_update, &new_entry, sizeof(new_entry));

return(1);

 }

 return(0);

}

Примечание

Обратите внимание на то, что вы не применяете функцию

gets
, поскольку нет способа проверить переполнение буфера. Всегда избегайте применения функции
gets

10. Теперь вы переходите к функции

enter_new_track_entries
для ввода информации о дорожке. Эта функция немного сложнее функции ввода элемента каталога, поскольку вы разрешаете существующему элементу-дорожке оставаться неизменным:

static void enter_new_track_entries(const cdc_entry *entry_to_add_to) {

 cdt_entry new_track, existing_track;

 char tmp_str[TMP_STRING_LEN + 1];

 int track_no = 1;

 if (entry_to_add_to->catalog[0] == '\0') return;

 printf("\nUpdating tracks for %s\n", entry_to_add_to->catalog);

 printf("Press return to leave existing description unchanged, \n");

 printf(" a single d to delete this and remaining tracks, \n");

 printf(" or new track description\n");

 while(1) {

11. Сначала вы должны проверить, существует ли уже дорожка с текущим номером дорожки. В зависимости от результатов проверки меняется строка приглашения:

memset(&new_track, '\0', sizeof(new_track));

existing_track = get_cdt_entry(entry_to_add_to->catalog,

track_no);

if (existing_track.catalog[0]) {

printf("\tTrack %d: %s\n", track_no,

existing_track.track_txt);

printf("\tNew text: ");

} else {

printf("\tTrack %d description: ", track_no);

}

fgets(tmp_str, TMP_STRING_LEN, stdin);

strip_return(tmp_str);

12. Если для данной дорожки не существует элемент и пользователь его не добавил, предположите, что больше нет дорожек, которые надо добавить:

if (strlen(tmp_str) == 0) {

if (existing_track.catalog[0] == '\0') {

/* Нет в наличии элемента, поэтому вставка завершается */

break;

} else {

/* Оставляем существующий элемент,

переходам к следующей дорожке */

track_no++;

continue;

}

}

13. Если пользователь введет единичный символ

d
, это приведет к удалению текущей дорожки и дорожек с большими номерами. Функция
del_cdt_entry
вернет
false
, если не сможет найти дорожку, которую следует удалить:

if ((strlen(tmp_str) == 1) && tmp_str[0] == 'd') { /* Удаляет эту и оставшиеся дорожки */

while (del_cdt_entry(entry_to_add_to->catalog, track_no)) {

track_no++;

}

break;

}

14. В этом пункте приводится код для вставки новой дорожки или обновления существующей. Вы формируете элемент

cdt_entry
структуры
new_track
и затем вызываете функцию базы данных
add_cdt_entry
для того, чтобы включить его в базу данных:

strncpy(new_track. track_txt, tmp_str, TRACK_TTEXT_LEN - 1);

strcpy(new_track.catalog, entry_to_add_to->catalog);

new_track.track_no = track_no;

if (!add_cdt_entry(new_track)) {

fprintf(stderr, "Failed to add new track\n");

break;

}

track_no++;

 } /* while */

}

15. Функция

del_cat_entry
удаляет элемент каталога. Никогда не разрешайте хранить дорожки для несуществующего элемента каталога.

static void del_cat_entry(const cdc_entry *entry_to_delete) {

 int track_no = 1;

 int delete_ok;

 display_cdc(entry_to_delete);

 if (get_confirm("Delete this entry and all it's tracks? ")) {

do {

delete_ok = del_cdt_entry(entry_to_delete->catalog, track_no);

track_no++;

} while(delete_ok);

if (!del_cdc_entry(entry_to_delete->catalog)) {

fprintf(stderr, "Failed to delete entry\n");

Поделиться:
Популярные книги

Аристократ из прошлого тысячелетия

Еслер Андрей
3. Соприкосновение миров
Фантастика:
фэнтези
попаданцы
аниме
5.00
рейтинг книги
Аристократ из прошлого тысячелетия

Искатель 3

Шиленко Сергей
3. Валинор
Фантастика:
попаданцы
рпг
фэнтези
5.00
рейтинг книги
Искатель 3

Я – Легенда

Гарцевич Евгений Александрович
1. Я - Легенда!
Фантастика:
боевая фантастика
попаданцы
рпг
фантастика: прочее
5.00
рейтинг книги
Я – Легенда

Имперец. Том 1 и Том 2

Романов Михаил Яковлевич
1. Имперец
Фантастика:
попаданцы
альтернативная история
аниме
5.00
рейтинг книги
Имперец. Том 1 и Том 2

Дракон с подарком

Суббота Светлана
3. Королевская академия Драко
Любовные романы:
любовно-фантастические романы
6.62
рейтинг книги
Дракон с подарком

Неудержимый. Книга XIX

Боярский Андрей
19. Неудержимый
Фантастика:
фэнтези
попаданцы
аниме
5.00
рейтинг книги
Неудержимый. Книга XIX

Рассвет русского царства. Книга 2

Грехов Тимофей
2. Новая Русь
Фантастика:
альтернативная история
попаданцы
историческое фэнтези
5.00
рейтинг книги
Рассвет русского царства. Книга 2

Первый среди равных. Книга VI

Бор Жорж
6. Первый среди Равных
Фантастика:
аниме
фэнтези
попаданцы
5.00
рейтинг книги
Первый среди равных. Книга VI

Газлайтер. Том 3

Володин Григорий
3. История Телепата
Фантастика:
попаданцы
альтернативная история
аниме
5.00
рейтинг книги
Газлайтер. Том 3

Кодекс Крови. Книга II

Борзых М.
2. РОС: Кодекс Крови
Фантастика:
фэнтези
попаданцы
аниме
5.00
рейтинг книги
Кодекс Крови. Книга II

На границе империй. Том 10. Часть 2

INDIGO
Вселенная EVE Online
Фантастика:
космическая фантастика
5.00
рейтинг книги
На границе империй. Том 10. Часть 2

Герой

Мазин Александр Владимирович
4. Варяг
Фантастика:
альтернативная история
9.10
рейтинг книги
Герой

На обочине 40 плюс. Кляча не для принца

Трофимова Любовь
Проза:
современная проза
5.00
рейтинг книги
На обочине 40 плюс. Кляча не для принца

Язычник

Мазин Александр Владимирович
5. Варяг
Приключения:
исторические приключения
8.91
рейтинг книги
Язычник