当前位置: 首页>>代码示例>>C#>>正文


C# IServiceProvider.LogInfo方法代码示例

本文整理汇总了C#中IServiceProvider.LogInfo方法的典型用法代码示例。如果您正苦于以下问题:C# IServiceProvider.LogInfo方法的具体用法?C# IServiceProvider.LogInfo怎么用?C# IServiceProvider.LogInfo使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在IServiceProvider的用法示例。


在下文中一共展示了IServiceProvider.LogInfo方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: AddBrokenTopicRequests

		private static void AddBrokenTopicRequests(
			IServiceProvider provider,
			IEnumerable<JanusMessageInfo> messages)
		{
			var freshMids = new Dictionary<int, JanusMessageInfo>();
			var parentIds = new Dictionary<int, int>();
			// Собираем все messageId и parentId
			foreach (var msg in messages)
			{
				freshMids[msg.messageId] = msg;
				if (msg.parentId != 0 && !ForumsSubscriptionHelper.IsTrashForum(msg.forumId)) // Skip roots & trash
					parentIds[msg.parentId] = msg.messageId;
			}

			// Удаляем тех родителей, которые уже присутствуют в том же пакете
			foreach (var parentId in parentIds.Keys.ToArray())
				if (freshMids.ContainsKey(parentId))
					parentIds.Remove(parentId);

			using (var dbMgr = provider.CreateDBContext())
			{
				var ids =
					dbMgr
						.Messages()
						.Where(msg => parentIds.Keys.ToArray().Contains(msg.ID))
						.Select(msg => msg.ID);
				// Удаляем тех родителей, которые присутствуют в БД
				foreach (var mid in ids)
					parentIds.Remove(mid);
			}

			// Оборванных веток нет - выходим
			if (parentIds.Count <= 0)
				return;

			provider.LogInfo(
				string.Format(
					parentIds.Count.GetDeclension(
						Resources.BrokenTopicMessage1,
						Resources.BrokenTopicMessage2,
						Resources.BrokenTopicMessage5),
					parentIds.Count,
					parentIds.Values.JoinToStringSeries(30).FirstOrDefault()));
			// Добавляем оставшиеся в запросы топиков
			// TODO: вменяемые строковые константы
			foreach (var mid in parentIds.Values)
				provider
					.GetOutboxManager()
					.DownloadTopics
					.Add(
						Resources.BrokenTopicRequestSource,
						mid,
						Resources.BrokenTopicRequestHint.FormatWith(freshMids[mid].subject));
		}
开发者ID:rsdn,项目名称:janus,代码行数:54,代码来源:MessagesSyncHelper.cs

示例2: SearchMessagesByLucene

		/// <summary>
		/// Поиск и выборка данных с использованием Lucene
		/// </summary>
		public static List<MsgBase> SearchMessagesByLucene(
			IServiceProvider provider,
			int forumId,
			string searchText,
			bool searchInText,
			bool searchInSubject,
			bool searchAuthor,
			bool searchInMarked,
			bool searchInMyMessages,
			bool searchAnyWords,
			bool searchInQuestions,
			DateTime from,
			DateTime to)
		{
			provider.LogInfo("Начат поиск...");
			var maxInClause = provider.MaxInClauseElements();

			provider.LogInfo("Используется lucene...");

			var mids =
				Search(
					forumId,
					searchText,
					searchInText,
					searchInSubject,
					searchAuthor,
					//searchInMarked,
					searchInMyMessages,
					searchAnyWords,
					//searchInQuestions,
					from,
					to);

			if (mids.Count == 0)
				return new List<MsgBase>(); // Ничего не нашли, вернём пустой список

			if (mids.Count > maxInClause)
				mids = Algorithms.GetFirstElements(mids, maxInClause);
			var intMids = mids.Select(int.Parse);

			using (var db = provider.CreateDBContext())
			{
				var q = db.Messages(m => intMids.Contains(m.ID));
				q = q.OrderByDescending(m => m.ID);

				// Обработка вопросов
				if (searchInQuestions)
					q = q.Where(m => m.TopicID == 0);

				// Обработка пометок пользователя
				if (searchInMarked)
					q = q.Where(m => m.IsMarked);

				var maxResults = Config.Instance.SearchConfig.MaxResultInSelect;
				if (maxResults > 0)
					q = q.Take(maxResults);

				var msgTable = db.Messages();
				var msgs =
					q
						.Select(
							m =>
								new LinearTreeMsg(provider)
								{
									ID = m.ID,
									ForumID = m.ForumID,
									TopicIDInternal = m.TopicID,
									ParentID = m.ParentID,
									Date = m.Date,
									UserID = m.UserID,
									UserNick = m.UserNick,
									UserClass = (short)m.UserClass,
									Subject = m.Subject,
									IsRead = m.IsRead,
									Rating = m.Rating(),
									Smiles = m.SmileCount(),
									Agrees = m.AgreeCount(),
									Disagrees = m.DisagreeCount(),
									RepliesCount = msgTable.Count(im => im.ParentID == m.ID),
								});
				var list =
					msgs
						.Cast<MsgBase>()
						.ToList();
				foreach (var msg in list)
					msg.EndMapping();
				return list;
			}
		}
开发者ID:rsdn,项目名称:janus,代码行数:92,代码来源:SearchHelper.cs


注:本文中的IServiceProvider.LogInfo方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。