pymud 0.21.4.post5__py3-none-any.whl → 0.21.5__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
pymud/extras.py CHANGED
@@ -626,6 +626,7 @@ class SessionBuffer(BufferBase):
626
626
  if line.endswith(self.newline):
627
627
  line = line.rstrip(self.newline)
628
628
  newline_after_append = True
629
+
629
630
  if not self.newline in line:
630
631
  if self._isnewline:
631
632
  self._lines.append(line)
@@ -659,6 +660,8 @@ class SessionBuffer(BufferBase):
659
660
  self._lines.clear()
660
661
  self.nosplit()
661
662
 
663
+ def forceNewline(self):
664
+ self._isnewline = True
662
665
 
663
666
  @property
664
667
  def lineCount(self):
@@ -713,9 +716,11 @@ class PyMudBufferControl(UIControl):
713
716
 
714
717
  # 为MUD显示进行校正的处理,包括对齐校正,换行颜色校正等
715
718
  self.FULL_BLOCKS = set("▂▃▅▆▇▄█━")
719
+ self.TABLE_LINES = set("┠┌└├┬┼┴╭╰─┨┘┐┤╮╯╔╚╠╦╪╩═╗╝╣┃││║")
716
720
  self.SINGLE_LINES = set("┠┌└├┬┼┴╭╰─")
717
- self.SINGLE_LINES_LEFT = set("┨┘┐┤")
721
+ self.SINGLE_LINES_LEFT = set("┨┘┐┤╮╯")
718
722
  self.DOUBLE_LINES = set("╔╚╠╦╪╩═")
723
+ self.DOUBLE_LINES_LEFT = set("╗╝╣")
719
724
  self.ALL_COLOR_REGX = re.compile(r"(?:\[[\d;]+m)+")
720
725
  self.AVAI_COLOR_REGX = re.compile(r"(?:\[[\d;]+m)+(?!$)")
721
726
  self._color_start = ""
@@ -737,7 +742,6 @@ class PyMudBufferControl(UIControl):
737
742
  """
738
743
  return False
739
744
 
740
-
741
745
  def width_correction(self, line: str) -> str:
742
746
  new_str = []
743
747
  for idx, ch in enumerate(line):
@@ -755,10 +759,13 @@ class PyMudBufferControl(UIControl):
755
759
  elif ch in self.SINGLE_LINES_LEFT:
756
760
  new_str.append("─")
757
761
  new_str.append(ch)
762
+ elif ch in self.DOUBLE_LINES_LEFT:
763
+ new_str.append("═")
764
+ new_str.append(ch)
758
765
  else:
759
- right = line[idx+1:]
766
+ right = str.rstrip(line[idx+1:])
760
767
  right_len = fragment_list_width(to_formatted_text(ANSI(right)))
761
- if right_len == 0:
768
+ if ((idx == len(line) - 1) or (right_len == 0)) and (ch in self.TABLE_LINES):
762
769
  new_str.append(" ")
763
770
  new_str.append(ch)
764
771
  else:
@@ -798,43 +805,6 @@ class PyMudBufferControl(UIControl):
798
805
 
799
806
  return line
800
807
 
801
- def fragment_correction(self, fragments: StyleAndTextTuples):
802
- """
803
- 处理ANSI标记,包括颜色标记,下划线标记等
804
- """
805
- new_fragments = []
806
- frag_count = len(fragments)
807
- for i in range(0, frag_count):
808
- style, text, *_ = fragments[i]
809
- new_text = []
810
-
811
- for j, ch in enumerate(text):
812
- if (east_asian_width(ch) in "FWA") and (wcwidth(ch) == 1):
813
- if ch in self.FULL_BLOCKS:
814
- new_text.append(ch * 2)
815
- elif ch in self.SINGLE_LINES:
816
- new_text.append(ch)
817
- new_text.append("─")
818
- elif ch in self.DOUBLE_LINES:
819
- new_text.append(ch)
820
- new_text.append("═")
821
- elif ch in self.SINGLE_LINES_LEFT:
822
- new_text.append("─")
823
- new_text.append(ch)
824
- elif (i == frag_count - 1) and (j == len(ch) - 1):
825
- new_text.append(" ")
826
- new_text.append(ch)
827
- else:
828
- new_text.append(ch)
829
- new_text.append(' ')
830
- else:
831
- new_text.append(ch)
832
-
833
- fragments[i] = (style, "".join(new_text))
834
-
835
- return fragments
836
-
837
-
838
808
  def create_content(self, width: int, height: int) -> UIContent:
839
809
  """
840
810
  Generate the content for this user control.
@@ -899,8 +869,10 @@ class PyMudBufferControl(UIControl):
899
869
 
900
870
  if selection_at_line:
901
871
  from_, to = selection_at_line
902
- # from_ = source_to_display(from_)
903
- # to = source_to_display(to)
872
+ total_display = fragment_list_width(fragments)
873
+ if to == len(buffer.getLine(i)):
874
+ to = total_display
875
+
904
876
 
905
877
  fragments = explode_text_fragments(fragments)
906
878
 
@@ -909,12 +881,14 @@ class PyMudBufferControl(UIControl):
909
881
  # visualize the selection.
910
882
  return [(selected_fragment, " ")]
911
883
  else:
912
- for i in range(from_, to):
884
+ for i in range(from_, min(to, total_display+1)):
913
885
  if i < len(fragments):
914
886
  old_fragment, old_text, *_ = fragments[i]
915
887
  fragments[i] = (old_fragment + selected_fragment, old_text)
916
- elif i == len(fragments):
917
- fragments.append((selected_fragment, " "))
888
+ # elif i == len(fragments):
889
+ # fragments.append((selected_fragment, " "))
890
+
891
+
918
892
 
919
893
  return fragments
920
894
 
pymud/pymud.py CHANGED
@@ -1084,12 +1084,8 @@ class PyMudApp:
1084
1084
  "命令行回车按键处理"
1085
1085
  cmd_line = buffer.text
1086
1086
  space_index = cmd_line.find(" ")
1087
-
1088
- if len(cmd_line) == 0:
1089
- if self.current_session:
1090
- self.current_session.writeline("")
1091
-
1092
- elif cmd_line[0] != Settings.client["appcmdflag"]:
1087
+
1088
+ if (len(cmd_line) >= 1) and (cmd_line[0] != Settings.client["appcmdflag"]):
1093
1089
  if self.current_session:
1094
1090
  self.current_session.last_command = cmd_line
1095
1091
 
@@ -1101,6 +1097,7 @@ class PyMudApp:
1101
1097
  if self.current_session:
1102
1098
  if len(cmd_line) == 0:
1103
1099
  self.current_session.writeline("")
1100
+
1104
1101
  else:
1105
1102
  try:
1106
1103
  self.current_session.log.log(f"{Settings.gettext('msg_cmdline_input')} {cmd_line}\n")
pymud/session.py CHANGED
@@ -810,6 +810,9 @@ class Session:
810
810
  else:
811
811
  if Settings.client["echo_input"]:
812
812
  self.writetobuffer(f"\x1b[32m{line}\x1b[0m", True)
813
+ elif len(line) == 0:
814
+ # 当向服务器仅送出空行时,本地强制后续显示换行
815
+ self.buffer.forceNewline()
813
816
  else:
814
817
  self.log.log(f"\x1b[32m{line}\x1b[0m\n")
815
818
 
pymud/settings.py CHANGED
@@ -15,7 +15,7 @@ class Settings:
15
15
  "APP 简要描述"
16
16
  __version__ = importlib.metadata.version("pymud")
17
17
  "APP 当前版本"
18
- __release__ = "2025-06-08"
18
+ __release__ = "2025-06-09"
19
19
  "APP 当前版本发布日期"
20
20
  __author__ = "本牛(newstart)@北侠"
21
21
  "APP 作者"
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: pymud
3
- Version: 0.21.4.post5
3
+ Version: 0.21.5
4
4
  Summary: a MUD Client written in Python
5
5
  Author-email: "newstart@pkuxkx" <crapex@hotmail.com>
6
6
  Maintainer-email: "newstart@pkuxkx" <crapex@hotmail.com>
@@ -66,6 +66,12 @@ Dynamic: license-file
66
66
 
67
67
  ## 版本更新信息
68
68
 
69
+ ### 0.21.5 (2025-06-09)
70
+
71
+ + 功能完善: 完善了美化功能,已知情况下,应该不会出现断行和不对齐问题了。
72
+ + 功能完善: 向服务器仅送出回车符号时,本地显示也强制换行。在出现『未完待续』情况时,回车后不会再跟在后面显示了,而是会强制从下一行开始。
73
+ + 功能完善: 当对行进行双击选择时,背景增加的选择标记(灰色)会按照实际显示的宽度进行匹配,而不是按照原始数据的宽度进行匹配。
74
+
69
75
  ### 0.21.4 (2025-06-08)
70
76
 
71
77
  + 问题修复: 修复了在多行选择碰到空行时,会导致从头开始全选的问题。
@@ -2,7 +2,7 @@ pymud/__init__.py,sha256=oeHz0NM7_DwChCY8f_vQ_fBq0e_HoTd0cahCFwaavWE,806
2
2
  pymud/__main__.py,sha256=lIOBiJmi8X-EWXVIx_OoxSgUZ0FYKlZI8hXVnLUYTJQ,61
3
3
  pymud/decorators.py,sha256=rNuDaKk65Cwc9K6t0-BpqNUORs8-8X5Xsv6YaLQ7hc4,9839
4
4
  pymud/dialogs.py,sha256=1xo5NJjch-u7RSRcclhvUE4gi8POgiZWK84lNx_HJbs,6891
5
- pymud/extras.py,sha256=WAtLEyKgdsEn0-BumToX6BfV29d5iXn7SUyAWM2JPZw,39146
5
+ pymud/extras.py,sha256=iadkEIIiRoFjRX8ezMxK3Dud6wuVf14ZbluXC0hfmuU,38284
6
6
  pymud/i18n.py,sha256=qLgvrmYhVfkTHKpbBR-LfYMOrGgi0skHrelbsj7ItbE,3034
7
7
  pymud/logger.py,sha256=F2LBUogdzv2WXHo10CNorDh2VleAX1Wbwmxc3zznHlM,5823
8
8
  pymud/main.py,sha256=zaSjNhpbX3FMulKg-UNFrdiIJO8sOmmrUQrkPOalB-4,10224
@@ -10,14 +10,14 @@ pymud/modules.py,sha256=CsOqY1c59CrejltCS4wf7QqdCr5k_ghel8AUqlKVGIw,11873
10
10
  pymud/objects.py,sha256=NlKAQnV6v9lSkz94zmgb513HPxskY8-tXnOdrYhuktc,38629
11
11
  pymud/pkuxkx.py,sha256=qDVry-Vd6MNui0NKWZFT52IpmP1sKS5Dz74EDY4tVGQ,14740
12
12
  pymud/protocol.py,sha256=noptJs6K0L9qM8VZIeP65H4k9FPLGJqxvm3qY2iAwvI,48315
13
- pymud/pymud.py,sha256=SrPGSls1QqrfSzctNpHV1gt_-M9WpOWi5cGH2VF8W6w,53483
14
- pymud/session.py,sha256=sTswAPEl5GWcxzYmgovG8lOlflNTd5k8ggW6zJ6vcMY,154690
15
- pymud/settings.py,sha256=V4wHKP2UjmX_l2bKJoUJSfNbH7vs3GZlN4u-1tRFbxA,7697
13
+ pymud/pymud.py,sha256=K1tTKlkE6y3oZDsP2t6iN5XNMQ1R_QE2um1JgI8THRg,53381
14
+ pymud/session.py,sha256=_ReMajT7uhTmyOppnUd9VScSFe6Hbl_smEaOD_hXJxc,154851
15
+ pymud/settings.py,sha256=YE-RWG-TRD92gIXsVrwY0VOCvjudl-68naFcgOfCJ7I,7697
16
16
  pymud/lang/i18n_chs.py,sha256=2cyaHHLwpYEBBwuQXyRTxa1opX53fTv1f8_QDQeGlC0,16836
17
17
  pymud/lang/i18n_eng.py,sha256=jcPz6Y5UuxJBQLY_e8UnEF3GYTlnAD44C14Oj7sK-QI,45935
18
- pymud-0.21.4.post5.dist-info/licenses/LICENSE.txt,sha256=OXLcl0T2SZ8Pmy2_dmlvKuetivmyPd5m1q-Gyd-zaYY,35149
19
- pymud-0.21.4.post5.dist-info/METADATA,sha256=vPX5Gp0V0ZHqPWUcWhaMVeeSDIn0roS7ZrlGmud44aI,46537
20
- pymud-0.21.4.post5.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
21
- pymud-0.21.4.post5.dist-info/entry_points.txt,sha256=diPUOtTkhgC1hVny7Cdg4aRhaHSynMQoraE7ZhJxUcw,37
22
- pymud-0.21.4.post5.dist-info/top_level.txt,sha256=8Gp1eXjxixXjqhhti6tLCspV_8s9sNV3z5Em2_KRhD4,6
23
- pymud-0.21.4.post5.dist-info/RECORD,,
18
+ pymud-0.21.5.dist-info/licenses/LICENSE.txt,sha256=OXLcl0T2SZ8Pmy2_dmlvKuetivmyPd5m1q-Gyd-zaYY,35149
19
+ pymud-0.21.5.dist-info/METADATA,sha256=YawLwvGN7CGEHNvmX5VGL3ADyDDiTHyze67MW-ySDXM,47052
20
+ pymud-0.21.5.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
21
+ pymud-0.21.5.dist-info/entry_points.txt,sha256=diPUOtTkhgC1hVny7Cdg4aRhaHSynMQoraE7ZhJxUcw,37
22
+ pymud-0.21.5.dist-info/top_level.txt,sha256=8Gp1eXjxixXjqhhti6tLCspV_8s9sNV3z5Em2_KRhD4,6
23
+ pymud-0.21.5.dist-info/RECORD,,