hg merge release-2.1 (merge release2.1 into development)

This commit is contained in:
Carlos Ruiz 2015-08-07 10:23:36 -05:00
commit 839a5370dc
9 changed files with 260 additions and 184 deletions

View File

@ -0,0 +1,11 @@
SET SQLBLANKLINES ON
SET DEFINE OFF
-- IDEMPIERE-2757 Key for M_Storage wrongly defined on dictionary
-- Aug 6, 2015 5:28:43 PM COT
UPDATE AD_Column SET IsParent='Y', IsUpdateable='N',Updated=TO_DATE('2015-08-06 17:28:43','YYYY-MM-DD HH24:MI:SS'),UpdatedBy=100 WHERE AD_Column_ID=210887
;
SELECT register_migration_script('201508061729_IDEMPIERE-2757.sql') FROM dual
;

View File

@ -0,0 +1,8 @@
-- IDEMPIERE-2757 Key for M_Storage wrongly defined on dictionary
-- Aug 6, 2015 5:28:43 PM COT
UPDATE AD_Column SET IsParent='Y', IsUpdateable='N',Updated=TO_TIMESTAMP('2015-08-06 17:28:43','YYYY-MM-DD HH24:MI:SS'),UpdatedBy=100 WHERE AD_Column_ID=210887
;
SELECT register_migration_script('201508061729_IDEMPIERE-2757.sql') FROM dual
;

View File

@ -598,17 +598,29 @@ public class MProduct extends X_M_Product
m_precision = null; m_precision = null;
// AttributeSetInstance reset // AttributeSetInstance reset
if (is_ValueChanged(COLUMNNAME_M_AttributeSet_ID)) if (getM_AttributeSetInstance_ID() > 0 && is_ValueChanged(COLUMNNAME_M_AttributeSet_ID))
{ {
MAttributeSetInstance asi = new MAttributeSetInstance(getCtx(), getM_AttributeSetInstance_ID(), get_TrxName()); MAttributeSetInstance asi = new MAttributeSetInstance(getCtx(), getM_AttributeSetInstance_ID(), get_TrxName());
setM_AttributeSetInstance_ID(0); if (asi.getM_AttributeSet_ID() != getM_AttributeSet_ID())
// Delete the old m_attributesetinstance setM_AttributeSetInstance_ID(0);
try { }
asi.deleteEx(true, get_TrxName()); if (!newRecord && is_ValueChanged(COLUMNNAME_M_AttributeSetInstance_ID))
} catch (AdempiereException ex) {
{ // IDEMPIERE-2752 check if the ASI is referenced in other products before trying to delete it
log.saveError("Error", "Error deleting the AttributeSetInstance"); int oldasiid = get_ValueOldAsInt(COLUMNNAME_M_AttributeSetInstance_ID);
return false; if (oldasiid > 0) {
MAttributeSetInstance oldasi = new MAttributeSetInstance(getCtx(), get_ValueOldAsInt(COLUMNNAME_M_AttributeSetInstance_ID), get_TrxName());
int cnt = DB.getSQLValueEx(get_TrxName(), "SELECT COUNT(*) FROM M_Product WHERE M_AttributeSetInstance_ID=?", oldasi.getM_AttributeSetInstance_ID());
if (cnt == 1) {
// Delete the old m_attributesetinstance
try {
oldasi.deleteEx(true, get_TrxName());
} catch (AdempiereException ex)
{
log.saveError("Error", "Error deleting the AttributeSetInstance");
return false;
}
}
} }
} }

View File

@ -1989,6 +1989,7 @@ public abstract class PO
*/ */
public boolean save() public boolean save()
{ {
checkValidContext();
CLogger.resetLast(); CLogger.resetLast();
boolean newRecord = is_new(); // save locally as load resets boolean newRecord = is_new(); // save locally as load resets
if (!newRecord && !is_Changed()) if (!newRecord && !is_Changed())
@ -3116,6 +3117,7 @@ public abstract class PO
*/ */
public boolean delete (boolean force) public boolean delete (boolean force)
{ {
checkValidContext();
CLogger.resetLast(); CLogger.resetLast();
if (is_new()) if (is_new())
return true; return true;
@ -4701,4 +4703,10 @@ public abstract class PO
log.saveError(msg, info); log.saveError(msg, info);
} }
} }
private void checkValidContext() {
if (getCtx().size() == 0)
throw new AdempiereException("Context lost");
}
} // PO } // PO

View File

@ -1616,7 +1616,7 @@ public final class Env
String foreignTable = colToken.getReferenceTableName(); String foreignTable = colToken.getReferenceTableName();
if (v != null) { if (v != null) {
if (format != null && format.length() > 0) { if (format != null && format.length() > 0) {
if (v instanceof Integer && (Integer) v > 0 && token.endsWith("_ID")) { if (v instanceof Integer && (Integer) v > 0 && !Util.isEmpty(foreignTable)) {
int tblIndex = format.indexOf("."); int tblIndex = format.indexOf(".");
String tableName = null; String tableName = null;
if (tblIndex > 0) if (tblIndex > 0)

View File

@ -57,8 +57,16 @@ public class PoFiller{
return; return;
else if (oldValue != null && oldValue.toString().equals(value)) else if (oldValue != null && oldValue.toString().equals(value))
return; return;
else else {
if (po instanceof MColumn && "IsToolbarButton".equals(columnName)) {
// IDEMPIERE-2064 - backward compatibility with 2packs generated before IDEMPIERE-2477
if ("true".equals(value))
value ="Y";
else if ("false".equals(value))
value ="N";
}
po.set_ValueNoCheck(columnName, value); po.set_ValueNoCheck(columnName, value);
}
} }
/** /**

View File

@ -1,8 +1,8 @@
/****************************************************************************** /******************************************************************************
* Product: Adempiere ERP & CRM Smart Business Solution * * Product: Adempiere ERP & CRM Smart Business Solution *
* Copyright (C) 1999-2006 ComPiere, Inc. All Rights Reserved. * * Copyright (C) 1999-2006 ComPiere, Inc. All Rights Reserved. *
* This program is free software; you can redistribute it and/or modify it * * This program is free software; you can redistribute it and/or modify it *
* under the terms version 2 of the GNU General Public License as published * * under the terms version 2 of the GNU General Public License as published *
* by the Free Software Foundation. This program is distributed in the hope * * by the Free Software Foundation. This program is distributed in the hope *
* that it will be useful, but WITHOUT ANY WARRANTY; without even the implied * * that it will be useful, but WITHOUT ANY WARRANTY; without even the implied *
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. * * warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. *
@ -16,62 +16,62 @@
*****************************************************************************/ *****************************************************************************/
package org.compiere.server; package org.compiere.server;
import java.sql.Timestamp; import java.sql.Timestamp;
import java.util.Properties; import java.util.Properties;
import java.util.logging.Level; import java.util.logging.Level;
import org.compiere.model.AdempiereProcessor; import org.adempiere.util.ServerContext;
import org.compiere.model.AdempiereProcessor2; import org.compiere.model.AdempiereProcessor;
import org.compiere.model.AdempiereProcessorLog; import org.compiere.model.AdempiereProcessor2;
import org.compiere.model.MClient; import org.compiere.model.AdempiereProcessorLog;
import org.compiere.model.MSchedule; import org.compiere.model.MClient;
import org.compiere.model.MSystem; import org.compiere.model.MSchedule;
import org.compiere.util.CLogger; import org.compiere.model.MSystem;
import org.compiere.util.Env; import org.compiere.model.PO;
import org.compiere.util.TimeUtil; import org.compiere.util.CLogger;
import org.compiere.util.Env;
/** import org.compiere.util.TimeUtil;
* Adempiere Server Base
* /**
* @author Jorg Janke * Adempiere Server Base
* @version $Id: AdempiereServer.java,v 1.3 2006/10/09 00:23:26 jjanke Exp $ *
*/ * @author Jorg Janke
public abstract class AdempiereServer implements Runnable * @version $Id: AdempiereServer.java,v 1.3 2006/10/09 00:23:26 jjanke Exp $
{ */
public abstract class AdempiereServer implements Runnable
{
/************************************************************************** /**************************************************************************
* Server Base Class * Server Base Class
* @param model model * @param model model
* @param initialNap delay time running in sec * @param initialNap delay time running in sec
*/ */
protected AdempiereServer (AdempiereProcessor model, int initialNap) protected AdempiereServer (AdempiereProcessor model, int initialNap)
{ {
p_model = model; p_model = model;
m_ctx = new Properties(model.getCtx()); if (p_system == null)
if (p_system == null) p_system = MSystem.get(model.getCtx());
p_system = MSystem.get(m_ctx); p_client = MClient.get(model.getCtx(), model.getAD_Client_ID());
p_client = MClient.get(m_ctx); m_initialNap = initialNap;
Env.setContext(m_ctx, "#AD_Client_ID", p_client.getAD_Client_ID());
m_initialNap = initialNap; Timestamp dateNextRun = getDateNextRun(true);
if (dateNextRun != null)
Timestamp dateNextRun = getDateNextRun(true); m_nextWork = dateNextRun.getTime();
if (dateNextRun != null)
m_nextWork = dateNextRun.getTime(); long now = System.currentTimeMillis();
if (m_nextWork > now)
long now = System.currentTimeMillis(); {
if (m_nextWork > now) m_sleepMS = m_nextWork - now;
{
m_sleepMS = m_nextWork - now;
} }
} // ServerBase } // ServerBase
/** The Processor Model */ /** The Processor Model */
protected volatile AdempiereProcessor p_model; protected volatile AdempiereProcessor p_model;
/** Initial nap is seconds */ /** Initial nap is seconds */
private int m_initialNap = 0; private int m_initialNap = 0;
/** Milliseconds to sleep - 0 Sec default */ /** Milliseconds to sleep - 0 Sec default */
protected long m_sleepMS = 0; protected long m_sleepMS = 0;
/** Sleeping */ /** Sleeping */
private volatile boolean m_sleeping = true; private volatile boolean m_sleeping = true;
/** Server start time */ /** Server start time */
@ -89,8 +89,6 @@ public abstract class AdempiereServer implements Runnable
/** Logger */ /** Logger */
protected CLogger log = CLogger.getCLogger(getClass()); protected CLogger log = CLogger.getCLogger(getClass());
/** Context */
private Properties m_ctx = null;
/** System */ /** System */
protected volatile static MSystem p_system = null; protected volatile static MSystem p_system = null;
/** Client */ /** Client */
@ -102,7 +100,7 @@ public abstract class AdempiereServer implements Runnable
*/ */
public Properties getCtx() public Properties getCtx()
{ {
return m_ctx; return Env.getCtx();
} // getCtx } // getCtx
/** /**
@ -112,18 +110,41 @@ public abstract class AdempiereServer implements Runnable
{ {
return m_sleepMS; return m_sleepMS;
} // getSleepMS } // getSleepMS
public long getInitialNap() public long getInitialNap()
{ {
return m_initialNap; return m_initialNap;
} }
public void runNow()
{
Properties context = new Properties();
Env.setContext(context, "#AD_Client_ID", p_model.getAD_Client_ID());
if (p_model instanceof PO) {
PO po = (PO) p_model;
if (po.get_ColumnIndex("AD_Org_ID") >= 0)
Env.setContext(context, "#AD_Org_ID", po.get_ValueAsInt("AD_Org_ID"));
if (po.get_ColumnIndex("AD_User_ID") >= 0)
Env.setContext(context, "#AD_User_ID", po.get_ValueAsInt("AD_User_ID"));
}
Properties prevContext = ServerContext.getCurrentInstance();
try {
ServerContext.setCurrentInstance(context);
m_sleeping = false;
doRunNow();
} finally {
ServerContext.dispose();
ServerContext.setCurrentInstance(prevContext);
m_sleeping = true;
}
}
/** /**
* Run Now * Run Now
*/ */
public void runNow() public void doRunNow()
{ {
m_sleeping = false;
p_startWork = System.currentTimeMillis(); p_startWork = System.currentTimeMillis();
doWork(); doWork();
long now = System.currentTimeMillis(); long now = System.currentTimeMillis();
@ -135,31 +156,55 @@ public abstract class AdempiereServer implements Runnable
// //
p_model.setDateLastRun(new Timestamp(now)); p_model.setDateLastRun(new Timestamp(now));
p_model.saveEx(); p_model.saveEx();
// //
if (log.isLoggable(Level.FINE)) if (log.isLoggable(Level.FINE))
log.fine(getStatistics()); log.fine(getStatistics());
m_sleeping = true;
} // runNow } // runNow
public void run()
{
final Thread currentThread = Thread.currentThread();
final String oldThreadName = currentThread.getName();
String newThreadName = getName();
boolean renamed = false;
if (!oldThreadName.equals(newThreadName)) {
try {
currentThread.setName(newThreadName);
renamed = true;
} catch (SecurityException e) {}
}
Properties context = new Properties();
Env.setContext(context, "#AD_Client_ID", p_model.getAD_Client_ID());
if (p_model instanceof PO) {
PO po = (PO) p_model;
if (po.get_ColumnIndex("AD_Org_ID") >= 0)
Env.setContext(context, "#AD_Org_ID", po.get_ValueAsInt("AD_Org_ID"));
if (po.get_ColumnIndex("AD_User_ID") >= 0)
Env.setContext(context, "#AD_User_ID", po.get_ValueAsInt("AD_User_ID"));
}
try {
ServerContext.setCurrentInstance(context);
m_sleeping = false;
doRun();
} finally {
m_sleeping = true;
ServerContext.dispose();
if (renamed) {
// Revert the name back if the current thread was renamed.
// We do not check the exception here because we know it works.
currentThread.setName(oldThreadName);
}
}
}
/************************************************************************** /**************************************************************************
* Run async * Run async
*/ */
public void run () protected void doRun()
{ {
final Thread currentThread = Thread.currentThread(); if (m_start == 0)
final String oldThreadName = currentThread.getName(); m_start = System.currentTimeMillis();
String newThreadName = getName();
boolean renamed = false;
if (!oldThreadName.equals(newThreadName)) {
try {
currentThread.setName(newThreadName);
renamed = true;
} catch (SecurityException e) {}
}
m_sleeping = false;
if (m_start == 0)
m_start = System.currentTimeMillis();
// --------------- // ---------------
p_startWork = System.currentTimeMillis(); p_startWork = System.currentTimeMillis();
@ -169,35 +214,29 @@ public abstract class AdempiereServer implements Runnable
p_runCount++; p_runCount++;
m_runLastMS = now - p_startWork; m_runLastMS = now - p_startWork;
m_runTotalMS += m_runLastMS; m_runTotalMS += m_runLastMS;
// Finished work - calculate datetime for next run // Finished work - calculate datetime for next run
Timestamp lastRun = new Timestamp(now); Timestamp lastRun = new Timestamp(now);
if (p_model instanceof AdempiereProcessor2) if (p_model instanceof AdempiereProcessor2)
{ {
AdempiereProcessor2 ap = (AdempiereProcessor2) p_model; AdempiereProcessor2 ap = (AdempiereProcessor2) p_model;
if (ap.isIgnoreProcessingTime()) if (ap.isIgnoreProcessingTime())
{ {
lastRun = new Timestamp(p_startWork); lastRun = new Timestamp(p_startWork);
} }
} }
m_nextWork = MSchedule.getNextRunMS(lastRun.getTime(), m_nextWork = MSchedule.getNextRunMS(lastRun.getTime(),
p_model.getScheduleType(), p_model.getFrequencyType(), p_model.getScheduleType(), p_model.getFrequencyType(),
p_model.getFrequency(), p_model.getCronPattern()); p_model.getFrequency(), p_model.getCronPattern());
m_sleepMS = m_nextWork - now; m_sleepMS = m_nextWork - now;
if (log.isLoggable(Level.INFO)) log.info(" Next run: " + new Timestamp(m_nextWork) + " sleep " + m_sleepMS); if (log.isLoggable(Level.INFO)) log.info(" Next run: " + new Timestamp(m_nextWork) + " sleep " + m_sleepMS);
// //
p_model.setDateLastRun(lastRun); p_model.setDateLastRun(lastRun);
p_model.setDateNextRun(new Timestamp(m_nextWork)); p_model.setDateNextRun(new Timestamp(m_nextWork));
p_model.saveEx(); p_model.saveEx();
m_sleeping = true;
if (renamed) {
// Revert the name back if the current thread was renamed.
// We do not check the exception here because we know it works.
currentThread.setName(oldThreadName);
}
} // run } // run
/** /**
@ -261,13 +300,13 @@ public abstract class AdempiereServer implements Runnable
} // getDescription } // getDescription
/** /**
* Get Model * Get Model
* @return Model * @return Model
*/ */
public AdempiereProcessor getModel() public AdempiereProcessor getModel()
{ {
return p_model; return p_model;
} // getModel } // getModel
/** /**
* Is Sleeping * Is Sleeping
@ -317,35 +356,35 @@ public abstract class AdempiereServer implements Runnable
} // getStartTime } // getStartTime
/** /**
* Get Processor Logs * Get Processor Logs
* @return logs * @return logs
*/ */
public AdempiereProcessorLog[] getLogs() public AdempiereProcessorLog[] getLogs()
{ {
return p_model.getLogs(); return p_model.getLogs();
} // getLogs } // getLogs
protected boolean isInterrupted() { protected boolean isInterrupted() {
return Thread.currentThread().isInterrupted(); return Thread.currentThread().isInterrupted();
} }
public String getName() { public String getName() {
return p_model.getName(); return p_model.getName();
} }
public static boolean isOKtoRunOnIP(AdempiereProcessor model) { public static boolean isOKtoRunOnIP(AdempiereProcessor model) {
if (model instanceof AdempiereProcessor2) { if (model instanceof AdempiereProcessor2) {
int AD_Schedule_ID = ((AdempiereProcessor2)model).getAD_Schedule_ID(); int AD_Schedule_ID = ((AdempiereProcessor2)model).getAD_Schedule_ID();
MSchedule schedule = MSchedule.get(Env.getCtx(), AD_Schedule_ID); MSchedule schedule = MSchedule.get(Env.getCtx(), AD_Schedule_ID);
if (!schedule.isOKtoRunOnIP()) if (!schedule.isOKtoRunOnIP())
{ {
return false; // done return false; // done
} }
} }
return true; return true;
} }
} // AdempiereServer } // AdempiereServer

View File

@ -27,10 +27,8 @@ import java.text.SimpleDateFormat;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Calendar; import java.util.Calendar;
import java.util.List; import java.util.List;
import java.util.Properties;
import java.util.logging.Level; import java.util.logging.Level;
import org.adempiere.util.ServerContext;
import org.compiere.model.MAttachment; import org.compiere.model.MAttachment;
import org.compiere.model.MClient; import org.compiere.model.MClient;
import org.compiere.model.MMailText; import org.compiere.model.MMailText;
@ -84,9 +82,6 @@ public class Scheduler extends AdempiereServer
/** Transaction */ /** Transaction */
protected Trx m_trx = null; protected Trx m_trx = null;
// ctx for the report/process
protected Properties m_schedulerctx = new Properties();
/** /**
* Work * Work
*/ */
@ -96,29 +91,27 @@ public class Scheduler extends AdempiereServer
.append(" - "); .append(" - ");
// Prepare a ctx for the report/process - BF [1966880] // Prepare a ctx for the report/process - BF [1966880]
m_schedulerctx.clear();
MClient schedclient = MClient.get(getCtx(), m_model.getAD_Client_ID()); MClient schedclient = MClient.get(getCtx(), m_model.getAD_Client_ID());
Env.setContext(m_schedulerctx, "#AD_Client_ID", schedclient.getAD_Client_ID()); Env.setContext(getCtx(), "#AD_Client_ID", schedclient.getAD_Client_ID());
Env.setContext(m_schedulerctx, "#AD_Language", schedclient.getAD_Language()); Env.setContext(getCtx(), "#AD_Language", schedclient.getAD_Language());
Env.setContext(m_schedulerctx, "#AD_Org_ID", m_model.getAD_Org_ID()); Env.setContext(getCtx(), "#AD_Org_ID", m_model.getAD_Org_ID());
if (m_model.getAD_Org_ID() != 0) { if (m_model.getAD_Org_ID() != 0) {
MOrgInfo schedorg = MOrgInfo.get(getCtx(), m_model.getAD_Org_ID(), null); MOrgInfo schedorg = MOrgInfo.get(getCtx(), m_model.getAD_Org_ID(), null);
if (schedorg.getM_Warehouse_ID() > 0) if (schedorg.getM_Warehouse_ID() > 0)
Env.setContext(m_schedulerctx, "#M_Warehouse_ID", schedorg.getM_Warehouse_ID()); Env.setContext(getCtx(), "#M_Warehouse_ID", schedorg.getM_Warehouse_ID());
} }
Env.setContext(m_schedulerctx, "#AD_User_ID", getAD_User_ID()); Env.setContext(getCtx(), "#AD_User_ID", getAD_User_ID());
Env.setContext(m_schedulerctx, "#SalesRep_ID", getAD_User_ID()); Env.setContext(getCtx(), "#SalesRep_ID", getAD_User_ID());
// TODO: It can be convenient to add AD_Scheduler.AD_Role_ID // TODO: It can be convenient to add AD_Scheduler.AD_Role_ID
MUser scheduser = MUser.get(getCtx(), getAD_User_ID()); MUser scheduser = MUser.get(getCtx(), getAD_User_ID());
MRole[] schedroles = scheduser.getRoles(m_model.getAD_Org_ID()); MRole[] schedroles = scheduser.getRoles(m_model.getAD_Org_ID());
if (schedroles != null && schedroles.length > 0) if (schedroles != null && schedroles.length > 0)
Env.setContext(m_schedulerctx, "#AD_Role_ID", schedroles[0].getAD_Role_ID()); // first role, ordered by AD_Role_ID Env.setContext(getCtx(), "#AD_Role_ID", schedroles[0].getAD_Role_ID()); // first role, ordered by AD_Role_ID
Timestamp ts = new Timestamp(System.currentTimeMillis()); Timestamp ts = new Timestamp(System.currentTimeMillis());
SimpleDateFormat dateFormat4Timestamp = new SimpleDateFormat("yyyy-MM-dd"); SimpleDateFormat dateFormat4Timestamp = new SimpleDateFormat("yyyy-MM-dd");
Env.setContext(m_schedulerctx, "#Date", dateFormat4Timestamp.format(ts)+" 00:00:00" ); // JDBC format Env.setContext(getCtx(), "#Date", dateFormat4Timestamp.format(ts)+" 00:00:00" ); // JDBC format
ServerContext.setCurrentInstance(m_schedulerctx);
MProcess process = new MProcess(m_schedulerctx, m_model.getAD_Process_ID(), null); MProcess process = new MProcess(getCtx(), m_model.getAD_Process_ID(), null);
try try
{ {
m_trx = Trx.get(Trx.createTrxName("Scheduler"), true); m_trx = Trx.get(Trx.createTrxName("Scheduler"), true);
@ -138,9 +131,6 @@ public class Scheduler extends AdempiereServer
m_trx.close(); m_trx.close();
} }
// clear thread local context
ServerContext.dispose();
// //
int no = m_model.deleteLog(); int no = m_model.deleteLog();
m_summary.append(" Logs deleted=").append(no); m_summary.append(" Logs deleted=").append(no);
@ -162,7 +152,7 @@ public class Scheduler extends AdempiereServer
if (log.isLoggable(Level.INFO)) log.info(process.toString()); if (log.isLoggable(Level.INFO)) log.info(process.toString());
boolean isReport = (process.isReport() || process.getAD_ReportView_ID() > 0 || process.getJasperReport() != null || process.getAD_PrintFormat_ID() > 0); boolean isReport = (process.isReport() || process.getAD_ReportView_ID() > 0 || process.getJasperReport() != null || process.getAD_PrintFormat_ID() > 0);
String schedulerName = Env.parseContext(m_schedulerctx, -1, m_model.getName(), false, true); String schedulerName = Env.parseContext(getCtx(), -1, m_model.getName(), false, true);
// Process (see also MWFActivity.performWork // Process (see also MWFActivity.performWork
int AD_Table_ID = m_model.getAD_Table_ID(); int AD_Table_ID = m_model.getAD_Table_ID();
@ -464,7 +454,7 @@ public class Scheduler extends AdempiereServer
String sql = variable.substring(5); // w/o tag String sql = variable.substring(5); // w/o tag
//sql = Env.parseContext(m_vo.ctx, m_vo.WindowNo, sql, false, true); // replace variables //sql = Env.parseContext(m_vo.ctx, m_vo.WindowNo, sql, false, true); // replace variables
//hengsin, capture unparseable error to avoid subsequent sql exception //hengsin, capture unparseable error to avoid subsequent sql exception
sql = Env.parseContext(m_schedulerctx, 0, sql, false, false); // replace variables sql = Env.parseContext(getCtx(), 0, sql, false, false); // replace variables
if (sql.equals("")) if (sql.equals(""))
log.log(Level.WARNING, "(" + sPara.getColumnName() + ") - Default SQL variable parse failed: " + variable); log.log(Level.WARNING, "(" + sPara.getColumnName() + ") - Default SQL variable parse failed: " + variable);
else { else {
@ -508,7 +498,7 @@ public class Scheduler extends AdempiereServer
String tail=index < (columnName.length()-1) ? columnName.substring(index+1) : null; String tail=index < (columnName.length()-1) ? columnName.substring(index+1) : null;
columnName = columnName.substring(0, index); columnName = columnName.substring(0, index);
// try Env // try Env
String env = Env.getContext(m_schedulerctx, columnName); String env = Env.getContext(getCtx(), columnName);
if (env == null || env.length() == 0) if (env == null || env.length() == 0)
env = Env.getContext(getCtx(), columnName); env = Env.getContext(getCtx(), columnName);
if (env.length() == 0) if (env.length() == 0)

View File

@ -253,7 +253,8 @@ public class WPAttributeDialog extends Window implements EventListener<Event>
MAttributeSet as = null; MAttributeSet as = null;
if (m_M_Product_ID != 0) int M_AttributeSet_ID = Env.getContextAsInt(Env.getCtx(), m_WindowNoParent, "M_AttributeSet_ID");
if (m_M_Product_ID != 0 && M_AttributeSet_ID == 0)
{ {
// Get Model // Get Model
m_masi = MAttributeSetInstance.get(Env.getCtx(), m_M_AttributeSetInstance_ID, m_M_Product_ID); m_masi = MAttributeSetInstance.get(Env.getCtx(), m_M_AttributeSetInstance_ID, m_M_Product_ID);
@ -269,7 +270,6 @@ public class WPAttributeDialog extends Window implements EventListener<Event>
} }
else else
{ {
int M_AttributeSet_ID = Env.getContextAsInt(Env.getCtx(), m_WindowNoParent, "M_AttributeSet_ID");
m_masi = new MAttributeSetInstance (Env.getCtx(), m_M_AttributeSetInstance_ID, M_AttributeSet_ID, null); m_masi = new MAttributeSetInstance (Env.getCtx(), m_M_AttributeSetInstance_ID, M_AttributeSet_ID, null);
as = m_masi.getMAttributeSet(); as = m_masi.getMAttributeSet();
} }