main=getLine>>=g.f
f(a:b:'x':c)=[read(a:b:"")-1,read c-1]
g[a,b]=mapM putStrLn[["+|-"!!h x y a b|x<-[0..a]]|y<-[0..b]]
y%b=min(max(y-1)0)(-y+b)
y#[a,b]=max(y+a-b)(-y+a)
h x y a b|x<y%b||x>y#[a,b]=1|x==y%b||x==y#[a,b]=0|1>0=2
main=do a:b:c:d<-getLine;g[read(a:[b])-1,read d-1]
g[a,b]=mapM putStrLn[["+|-"!!h x y a b|x<-[0..a]]|y<-[0..b]]
y%b=min(max(y-1)0)(b-y)
y#[a,b]=max(y+a-b)(a-y)
h x y a b|x<y%b||x>y#[a,b]=1|x==y%b||x==y#[a,b]=0|1>0=2
main=do a:b:c:d<-getLine;g[read(a:[b])-1,read d-1]
g[a,b]=mapM putStrLn[["+|-"!!h x y a b|x<-[0..a]]|y<-[0..b]]
y%b=min(max(y-1)0)(b-y)
h x y a b|x<y%b||x>max(y+a-b)(a-y)=1|x==y%b||x==max(y+a-b)(a-y)=0|1>0=2
【修正3】 181バイト
main=do a:b:c:d<-getLine;f$map read[a:[b],d]
f[a,b]=mapM putStrLn[["+|-"!!h(max(y+a-b)(a-y+1))x(min(max(y-1)1)(b+1-y))y|x<-[1..a]]|y<-[1..b]]
h s x t y|x<t||x>s=1|x==t||x==s=0|1>0=2
【修正4】 179バイト
main=do a:b:c:d<-getLine;f$map read[a:[b],d]
f[a,b]=mapM putStrLn[["+|-"!!h(x-max(y+a-b)(a-y+1))(x-min(max(y-1)1)(b+1-y))|x<-[1..a]]|y<-[1..b]]
h a b|b<0||a>0=1|b==0||a==0=0|1>0=2
【修正5】 178バイト
main=do a:b:c:d<-getLine;f$map read[a:[b],d]
f[a,b]=mapM putStrLn[["+|-"!!h(max(y+a-b)(a-y+1))x(min(max(y-1)1)(b+1-y))|x<-[1..a]]|y<-[1..b]]
h s x t|x<t||x>s=1|x==t||x==s=0|1>0=2
main=do a:b:c:d<-getLine;f$map read[a:[b],d]
f[a,b]=mapM putStrLn[["+|-"!!h(x-max(y+a-b)(a-y+1))(x-min(max(y-1)1)(b+1-y))|x<-[1..a]]|y<-[1..b]]
h a b|a>0||b<0=1|a*b==0=0|1>0=2