Merge branch 'master' of github.com:KLayout/klayout

This commit is contained in:
Matthias Koefferlein 2025-01-04 19:36:43 +01:00
commit 2d5ddd794c
9 changed files with 65 additions and 21 deletions

View File

@ -56,7 +56,7 @@ jobs:
HOST_CCACHE_DIR="$(ccache -k cache_dir)"
mkdir -p $HOST_CCACHE_DIR
- name: Build wheels # check https://cibuildwheel.readthedocs.io/en/stable/setup/#github-actions
uses: pypa/cibuildwheel@v2.21.3
uses: pypa/cibuildwheel@v2.22.0
# to supply options, put them in 'env', like:
# env:
# CIBW_SOME_OPTION: value
@ -103,7 +103,7 @@ jobs:
name: artifact
path: dist
- uses: pypa/gh-action-pypi-publish@v1.11.0
- uses: pypa/gh-action-pypi-publish@v1.12.3
continue-on-error: true # might fail if we don't bump the version
with:
user: __token__
@ -120,7 +120,7 @@ jobs:
name: artifact
path: dist
- uses: pypa/gh-action-pypi-publish@v1.11.0
- uses: pypa/gh-action-pypi-publish@v1.12.3
with:
user: __token__
password: ${{ secrets.pypi_password }}

View File

@ -1298,7 +1298,7 @@ AsIfFlatRegion::sized (coord_type dx, coord_type dy, unsigned int mode) const
// simplified handling for a box
db::Box b = bbox ().enlarged (db::Vector (dx, dy));
return region_from_box (b, properties_repository (), begin ()->prop_id ());
return region_from_box (b, properties_repository (), db::RegionIterator (begin ()).prop_id ());
} else if (! merged_semantics () || is_merged ()) {
@ -1478,13 +1478,13 @@ AsIfFlatRegion::and_with (const Region &other, PropertyConstraint property_const
} else if (is_box () && other.is_box ()) {
if (pc_skip (property_constraint) || pc_match (property_constraint, begin ()->prop_id (), other.begin ().prop_id ())) {
if (pc_skip (property_constraint) || pc_match (property_constraint, db::RegionIterator (begin ()).prop_id (), other.begin ().prop_id ())) {
// Simplified handling for boxes
db::Box b = bbox ();
b &= other.bbox ();
db::properties_id_type prop_id_out = pc_norm (property_constraint, begin ()->prop_id ());
db::properties_id_type prop_id_out = pc_norm (property_constraint, db::RegionIterator (begin ()).prop_id ());
return region_from_box (b, properties_repository (), prop_id_out);
@ -1494,7 +1494,7 @@ AsIfFlatRegion::and_with (const Region &other, PropertyConstraint property_const
} else if (is_box () && ! other.strict_handling ()) {
db::properties_id_type self_prop_id = pc_skip (property_constraint) ? 0 : begin ()->prop_id ();
db::properties_id_type self_prop_id = pc_skip (property_constraint) ? 0 : db::RegionIterator (begin ()).prop_id ();
// map AND with box to clip ..
db::Box b = bbox ();

View File

@ -784,7 +784,6 @@ RegionDelegate *
DeepRegion::and_with (const Region &other, PropertyConstraint property_constraint) const
{
const DeepRegion *other_deep = dynamic_cast <const DeepRegion *> (other.delegate ());
if (empty ()) {
return clone ()->remove_properties (pc_remove (property_constraint));

View File

@ -31,6 +31,9 @@
namespace db
{
template <class T>
class generic_shape_iterator;
template <class T>
class DB_PUBLIC generic_shape_iterator_delegate_base
{
@ -40,6 +43,9 @@ public:
generic_shape_iterator_delegate_base () { }
virtual ~generic_shape_iterator_delegate_base () { }
protected:
friend class generic_shape_iterator<T>;
virtual void do_reset (const db::Box & /*region*/, bool /*overlapping*/) { }
virtual db::Box bbox () const { return db::Box::world (); }
virtual bool is_addressable () const = 0;
@ -62,6 +68,7 @@ public:
: m_iter (from), m_from (from), m_to (to)
{ }
protected:
virtual bool is_addressable () const
{
return addressable;
@ -122,6 +129,7 @@ public:
: m_iter (from), m_from (from)
{ }
protected:
virtual bool is_addressable () const
{
return addressable;
@ -185,6 +193,7 @@ public:
set ();
}
protected:
virtual bool is_addressable () const
{
return m_is_addressable;

View File

@ -614,7 +614,7 @@ PCellParametersPage::setup (lay::LayoutViewBase *view, int cv_index, const db::P
m_initial_states = m_states;
mp_error_frame->hide ();
update_widgets_from_states (m_states);
update_widgets_from_states (m_states, lazy_evaluation ());
mp_parameters_area->setWidget (mp_main_frame);
mp_main_frame->show ();
@ -713,7 +713,7 @@ PCellParametersPage::do_parameter_changed ()
db::ParameterStates states = m_states;
get_parameters (states, &ok); // includes coerce
if (ok) {
update_widgets_from_states (states);
update_widgets_from_states (states, lazy_evaluation ());
if (! lazy_evaluation ()) {
emit edited ();
}
@ -959,11 +959,11 @@ PCellParametersPage::set_parameters (const std::vector<tl::Variant> &parameters)
m_initial_states = m_states;
mp_error_frame->hide ();
set_parameters_internal (m_states, false);
update_widgets_from_states (m_states, false);
}
void
PCellParametersPage::update_widgets_from_states (const db::ParameterStates &states)
PCellParametersPage::update_widgets_from_states (const db::ParameterStates &states, bool tentatively)
{
if (! mp_pcell_decl) {
return;
@ -1031,7 +1031,7 @@ PCellParametersPage::update_widgets_from_states (const db::ParameterStates &stat
}
set_parameters_internal (states, lazy_evaluation ());
set_parameters_internal (states, tentatively);
// QGridLayouts are bad in handling nested QFrame (or QGroupBox) with their own layouts,
// so we help a little here:

View File

@ -177,7 +177,7 @@ private:
bool lazy_evaluation ();
void set_parameters_internal (const db::ParameterStates &states, bool tentatively);
bool update_current_parameters ();
void update_widgets_from_states (const db::ParameterStates &states);
void update_widgets_from_states (const db::ParameterStates &states, bool tentatively);
void get_parameters_internal (db::ParameterStates &states, bool &edit_error);
std::vector<tl::Variant> parameter_from_states (const db::ParameterStates &states) const;
void states_from_parameters (db::ParameterStates &states, const std::vector<tl::Variant> &parameters);

View File

@ -293,7 +293,8 @@ public:
}
END_PROTECTED
// Note: Qt does not like popups during drag-and-drop operations ...
END_PROTECTED_SILENT
}
void dragLeaveEvent (QDragLeaveEvent * /*event*/)
@ -309,7 +310,8 @@ public:
svc = next;
}
END_PROTECTED
// Note: Qt does not like popups during drag-and-drop operations ...
END_PROTECTED_SILENT
}
void dragMoveEvent (QDragMoveEvent *event)
@ -332,7 +334,8 @@ public:
}
END_PROTECTED
// Note: Qt does not like popups during drag-and-drop operations ...
END_PROTECTED_SILENT
}
void dropEvent (QDropEvent *event)
@ -355,7 +358,8 @@ public:
}
END_PROTECTED
// Note: Qt does not like popups during drag-and-drop operations ...
END_PROTECTED_SILENT
}
void mouseMoveEvent (QMouseEvent *e)

View File

@ -404,13 +404,13 @@ DataMappingLookupTable::update_table (double xmin, double xmax, double delta_y,
double dx = fabs (t->first - t[-1].first);
double dy = fabs (t->second - t[-1].second);
if (dx * delta_y < delta_x * dy) {
if (dx > 1e-10 && dy > 1e-10 && dx * delta_y < delta_x * dy) {
delta_x = dx / dy * delta_y;
}
}
size_t nsteps = size_t (ceil((xmax - xmin) / delta_x - 1e-6));
size_t nsteps = size_t (ceil ((xmax - xmin) / delta_x - 1e-6));
// Limit the number of interpolation points (this is an arbitrary number - it could be somewhat else)
nsteps = std::min (size_t (16384), nsteps);
@ -422,7 +422,9 @@ DataMappingLookupTable::update_table (double xmin, double xmax, double delta_y,
std::vector< std::pair<double, double> >::const_iterator t = table.begin ();
size_t i = 0;
for (double x = xmin; i < nsteps; ++i, x += delta_x) {
double x;
for ( ; i < nsteps; ++i) {
x = xmin + i * delta_x;
while (t != table.end () && t->first <= x) {
++t;
}

View File

@ -1498,6 +1498,36 @@ class DBRegion_TestClass < TestBase
end
# issue #1955 (locking of layout object inside DSS)
def test_issue1955
ly = RBA::Layout::new
top = ly.create_cell("TOP")
l1 = ly.layer(1, 0)
dss = RBA::DeepShapeStore::new
rr = RBA::Region::new(RBA::Box::new(100, 100, 1100, 1100))
r = RBA::Region::new(top.begin_shapes_rec(l1), dss)
r += RBA::Region::new(RBA::Box::new(0, 0, 1000, 1000))
# this spoils the dss object, if
# 1. the first region is a deep region
# 2. the second region is a flat region
# 3. both regions are boxes
# after this operation, bounding boxes are no
# longer updated inside the DSS.
randrr = r & rr
assert_equal(randrr.to_s, "(100,100;100,1000;1000,1000;1000,100)")
r += RBA::Region::new(RBA::Box::new(1000, 1000, 2000, 2000))
assert_equal(r.to_s, "(0,0;0,1000;1000,1000;1000,0);(1000,1000;1000,2000;2000,2000;2000,1000)")
assert_equal(r.bbox.to_s, "(0,0;2000,2000)")
end
end
load("test_epilogue.rb")