| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114 |
- //
- // System.Web.UI.BaseParser.cs
- //
- // Authors:
- // Duncan Mak ([email protected])
- // Gonzalo Paniagua Javier ([email protected])
- //
- // (C) 2002 Ximian, Inc. (http://www.ximian.com)
- //
- using System;
- using System.Collections;
- using System.IO;
- using System.Web;
- using System.Web.Compilation;
- using System.Web.Util;
- namespace System.Web.UI
- {
- public class BaseParser
- {
- HttpContext context;
- string baseDir;
- string baseVDir;
- ILocation location;
- internal string MapPath (string path)
- {
- return MapPath (path, true);
- }
- internal string MapPath (string path, bool allowCrossAppMapping)
- {
- if (context == null)
- throw new HttpException ("context is null!!");
- return context.Request.MapPath (path, BaseVirtualDir, allowCrossAppMapping);
- }
- internal string PhysicalPath (string path)
- {
- if (Path.DirectorySeparatorChar != '/')
- path = path.Replace ('/', '\\');
-
- return Path.Combine (BaseDir, path);
- }
- internal bool GetBool (Hashtable hash, string key, bool deflt)
- {
- string val = hash [key] as string;
- if (val == null)
- return deflt;
- hash.Remove (key);
- bool result = false;
- if (String.Compare (val, "true", true) == 0)
- result = true;
- else if (String.Compare (val, "false", true) != 0)
- ThrowParseException ("Invalid value for " + key);
- return result;
- }
- internal static string GetString (Hashtable hash, string key, string deflt)
- {
- string val = hash [key] as string;
- if (val == null)
- return deflt;
- hash.Remove (key);
- return val;
- }
-
- internal void ThrowParseException (string message)
- {
- throw new ParseException (location, message);
- }
-
- internal void ThrowParseException (string message, Exception inner)
- {
- throw new ParseException (location, message, inner);
- }
-
- internal ILocation Location {
- get { return location; }
- set { location = value; }
- }
- internal HttpContext Context {
- get { return context; }
- set { context = value; }
- }
- internal string BaseDir {
- get {
- if (baseDir == null)
- baseDir = MapPath (BaseVirtualDir, false);
- return baseDir;
- }
- }
- internal virtual string BaseVirtualDir {
- get {
- if (baseVDir == null)
- baseVDir = UrlUtils.GetDirectory (context.Request.FilePath);
- return baseVDir;
- }
- }
- }
- }
|