if(!EmptyString(line))
{
lineptr = rb_malloc(sizeof(struct cacheline));
- rb_strlcpy(lineptr->data, line, sizeof(lineptr->data));
+ untabify(lineptr->data, line, sizeof(lineptr->data));
rb_dlinkAddTail(lineptr, &lineptr->linenode, &cacheptr->contents);
}
else
rb_dlinkAddTailAlloc(emptyline, &cacheptr->contents);
}
+ if (0 == rb_dlink_list_length(&cacheptr->contents))
+ {
+ /* No contents. Don't cache it after all. */
+ rb_free(cacheptr);
+ cacheptr = NULL;
+ }
+
fclose(in);
return cacheptr;
}
struct cachefile *cacheptr;
struct DictionaryIter iter;
+#if defined(S_ISLNK) && defined(HAVE_LSTAT)
+ struct stat sb;
+#endif
+
DICTIONARY_FOREACH(cacheptr, &iter, help_dict_oper)
{
irc_dictionary_delete(help_dict_oper, cacheptr->name);
while((ldirent = readdir(helpfile_dir)) != NULL)
{
+ if(ldirent->d_name[0] == '.')
+ continue;
rb_snprintf(filename, sizeof(filename), "%s/%s", HPATH, ldirent->d_name);
cacheptr = cache_file(filename, ldirent->d_name, HELP_OPER);
irc_dictionary_add(help_dict_oper, cacheptr->name, cacheptr);
while((ldirent = readdir(helpfile_dir)) != NULL)
{
+ if(ldirent->d_name[0] == '.')
+ continue;
rb_snprintf(filename, sizeof(filename), "%s/%s", UHPATH, ldirent->d_name);
+#if defined(S_ISLNK) && defined(HAVE_LSTAT)
+ if(lstat(filename, &sb) < 0)
+ continue;
+
+ /* ok, if its a symlink, we work on the presumption if an
+ * oper help exists of that name, its a symlink to that --fl
+ */
+ if(S_ISLNK(sb.st_mode))
+ {
+ cacheptr = irc_dictionary_retrieve(help_dict_oper, ldirent->d_name);
+
+ if(cacheptr != NULL)
+ {
+ cacheptr->flags |= HELP_USER;
+ continue;
+ }
+ }
+#endif
+
cacheptr = cache_file(filename, ldirent->d_name, HELP_USER);
irc_dictionary_add(help_dict_user, cacheptr->name, cacheptr);
}