本文整理匯總了C#中MindTouch.Dream.MimeType.Match方法的典型用法代碼示例。如果您正苦於以下問題:C# MimeType.Match方法的具體用法?C# MimeType.Match怎麽用?C# MimeType.Match使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類MindTouch.Dream.MimeType
的用法示例。
在下文中一共展示了MimeType.Match方法的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。
示例1: AppendDiff
//.........這裏部分代碼省略.........
diffXml.Start("hr").Attr("width", "100%").Attr("size", "2").End();
diffXml.AddNodes(diff);
diffXml.Start("hr").Attr("width", "100%").Attr("size", "2").End();
// check if there are invisible changes as well to show
if(!invisibleDiff.IsEmpty) {
diffXml.Start("p").Elem("strong", resources.Localize(DekiResources.PAGE_DIFF_OTHER_CHANGES())).End();
diffXml.Add(invisibleDiff);
}
} else if(!invisibleDiff.IsEmpty) {
// only show invisible changes
diffXml.Start("hr").Attr("width", "100%").Attr("size", "2").End();
diffXml.Start("p").Elem("strong", resources.Localize(DekiResources.PAGE_DIFF_OTHER_CHANGES())).End();
diffXml.Add(invisibleDiff);
} else if(beforeDoc.IsEmpty && afterDoc.IsEmpty) {
// show message that page contents were not available anymore
diffXml.Elem("p", resources.Localize(DekiResources.PAGE_NOT_AVAILABLE()));
}
diffXml.End();
// store diff in cache
if(diffCacheEnabled && !afterDoc.IsEmpty) {
store.With("ttl", TimeSpan.FromDays(30).TotalSeconds).Put(diffXml, new Result<DreamMessage>(TimeSpan.MaxValue)).Block();
}
}
body.AddNodes(diffXml);
}
// check if we have a comment text
if(Utils.IsPageComment(type)) {
string text = change.CmntContent;
if(!string.IsNullOrEmpty(text) && !change.CmntDeleted) {
MimeType mime = new MimeType(change.CmntMimetype ?? MimeType.TEXT_UTF8.ToString());
if(mime.Match(MimeType.HTML)) {
XDoc html = XDocFactory.From(string.Format("<html><body>{0}</body></html>", text), MimeType.HTML);
body.Start("blockquote").AddNodes(html["body"]).End();
} else {
// anything else should be consider to be text
body.Start("blockquote").Elem("p", text).End();
}
} else {
// anything else should be consider to be text
body.Start("blockquote").Elem("p", resources.Localize(DekiResources.COMMENT_NOT_AVAILABLE())).End();
}
}
// adds links
body.Start("table").Attr("border", 0).Attr("padding", "5").Attr("width", "80%").Start("tr");
// add link for viewing the page
if(change.PageExists) {
Title view = new Title(title);
body.Start("td").Start("a").Attr("href", Utils.AsPublicUiUri(view, true)).Value(resources.Localize(DekiResources.VIEW_PAGE())).End().End();
}
// check if we need to add link for editing the page
if(after.HasValue && before.HasValue && (after != before)) {
Title edit = new Title(title) { Query = "action=edit" };
body.Start("td").Start("a").Attr("href", Utils.AsPublicUiUri(edit)).Value(resources.Localize(DekiResources.EDIT_PAGE())).End().End();
}
// check if we need to add link for viewing the complete diff
if(after.HasValue && before.HasValue && (after != before)) {
Title show = new Title(title) { Query = string.Format("diff={0}&revision={1}", after.Value, before.Value) };
body.Start("td").Start("a").Attr("href", Utils.AsPublicUiUri(show, true)).Value(resources.Localize(DekiResources.VIEW_PAGE_DIFF())).End().End();
}
// check if we need to add link for seeing full page history
if(after.HasValue && before.HasValue && (after != before)) {
Title history = new Title(title) { Query = "action=history" };
body.Start("td").Start("a").Attr("href", Utils.AsPublicUiUri(history)).Value(resources.Localize(DekiResources.VIEW_PAGE_HISTORY())).End().End();
}
// check if we need to add link for banning the user
List<KeyValuePair<string, string>> authors = change.SortedAuthors;
if((authors == null) || (authors.Count == 0)) {
authors = new List<KeyValuePair<string, string>> { new KeyValuePair<string, string>(change.Username, change.Fullname) };
}
for(int i = 0; i < authors.Count; ++i) {
string username = authors[i].Key;
string fullname = authors[i].Value;
if(!string.IsNullOrEmpty(username)) {
// don't put up ban link for admins.
UserBE user = DbUtils.CurrentSession.Users_GetByName(username);
if(!UserBL.IsAnonymous(user) && !PermissionsBL.IsUserAllowed(user, Permissions.ADMIN)) {
Title ban = Title.FromUIUri(null, "Special:Userban");
ban.Query += string.Format("username={0}", username);
body.Start("td").Start("a").Attr("href", Utils.AsPublicUiUri(ban)).Value(resources.Localize(DekiResources.BAN_USER(string.IsNullOrEmpty(fullname) ? username : fullname))).End().End();
}
}
}
// close HTML
body.End().End();
}
示例2: From
/// <summary>
/// Create a document from a text reader.
/// </summary>
/// <param name="reader">Document text reader.</param>
/// <param name="mime">Document mime-type.</param>
/// <returns>New document instance.</returns>
public static XDoc From(TextReader reader, MimeType mime)
{
if(reader == null) {
throw new ArgumentNullException("reader");
}
if(mime == null) {
throw new ArgumentNullException("mime");
}
if(mime.Match(MimeType.VCAL)) {
return VersitUtil.FromVersit(reader, "vcal");
}
if(mime.Match(MimeType.VERSIT)) {
return VersitUtil.FromVersit(reader, "vcard");
}
if(mime.Match(MimeType.HTML)) {
return FromHtml(reader);
}
if(mime.IsXml) {
return FromXml(reader);
}
if(mime.Match(MimeType.FORM_URLENCODED)) {
return XPostUtil.FromXPathValuePairs(XUri.ParseParamsAsPairs(reader.ReadToEnd()), "form");
}
throw new ArgumentException("unsupported mime-type: " + mime.FullType, "mime");
}
示例3: ResolvePreviewFormat
/// <summary>
/// Given the mimetype of an original file, return the formattype for the preview images to be used by imagemagick
/// </summary>
/// <param name="mime"></param>
/// <returns></returns>
private static FormatType ResolvePreviewFormat(MimeType mime) {
if(mime.Match(MimeType.JPEG) || mime.Match(new MimeType("image/x-jpeg"))) {
return FormatType.JPG;
}
if(mime.Match(MimeType.PNG) || mime.Match(new MimeType("image/x-png"))) {
return FormatType.PNG;
}
if(mime.Match(MimeType.BMP) || mime.Match(new MimeType("image/x-bmp"))) {
return FormatType.BMP;
}
if(mime.Match(MimeType.GIF) || mime.Match(new MimeType("image/x-gif"))) {
return FormatType.GIF;
}
return FormatType.JPG;
}
示例4: AddText
/// <summary>
/// Add text to the document.
/// </summary>
/// <param name="tag">Enclosing tag for the text.</param>
/// <param name="mime">Mime type of the enclosed text.</param>
/// <param name="xml">The body document to add.</param>
/// <returns>Returns the current document instance.</returns>
public XAtomBase AddText(string tag, MimeType mime, XDoc xml)
{
if(mime.Match(MimeType.XHTML)) {
Start(tag).Attr("type", "xhtml");
// add content and normalize the root node
XDoc added = xml.Clone().Rename("div");
if(added["@xmlns"].IsEmpty) {
added.Attr("xmlns", "http://www.w3.org/1999/xhtml");
}
Add(added);
} else if(mime.Match(MimeType.HTML)) {
Start(tag).Attr("type", "html");
// embed HTML as text
Value(xml.ToInnerXHtml());
} else {
Start(tag).Attr("type", mime.FullType);
Add(xml);
}
// close element
End();
return this;
}
示例5: MimeTypeCanBeInlined
public bool MimeTypeCanBeInlined(MimeType mimeType) {
if(_inlineDispositionBlacklist == null) {
string[] blackliststrings = ConfigBL.GetInstanceSettingsValue("files/blacklisted-disposition-mimetypes", string.Empty).ToLowerInvariant().Split(new char[] { ',', ' ' }, StringSplitOptions.RemoveEmptyEntries);
List<MimeType> blacklist = new List<MimeType>();
foreach(string v in blackliststrings) {
MimeType mt = MimeType.New(v);
if(mt != null) {
blacklist.Add(mt);
}
}
string[] whiteliststrings = ConfigBL.GetInstanceSettingsValue("files/whitelisted-disposition-mimetypes", string.Empty).ToLowerInvariant().Split(new char[] { ',', ' ' }, StringSplitOptions.RemoveEmptyEntries);
List<MimeType> whitelist = new List<MimeType>();
foreach(string v in whiteliststrings) {
MimeType mt = MimeType.New(v);
if(mt != null) {
whitelist.Add(mt);
}
}
_inlineDispositionBlacklist = blacklist;
_inlineDispositionWhitelist = whitelist;
}
foreach(MimeType bad in _inlineDispositionBlacklist) {
if(mimeType.Match(bad)) {
return false;
}
}
foreach(MimeType good in _inlineDispositionWhitelist) {
if(mimeType.Match(good)) {
return true;
}
}
return false;
}