@langchain/core 0.3.30 → 0.3.32

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.
@@ -81,7 +81,7 @@ function _mergeMessageRuns(messages) {
81
81
  }
82
82
  const merged = [];
83
83
  for (const msg of messages) {
84
- const curr = msg; // Create a shallow copy of the message
84
+ const curr = msg;
85
85
  const last = merged.pop();
86
86
  if (!last) {
87
87
  merged.push(curr);
@@ -113,7 +113,9 @@ function trimMessages(messagesOrOptions, options) {
113
113
  }
114
114
  else {
115
115
  const trimmerOptions = messagesOrOptions;
116
- return base_js_1.RunnableLambda.from((input) => _trimMessagesHelper(input, trimmerOptions));
116
+ return base_js_1.RunnableLambda.from((input) => _trimMessagesHelper(input, trimmerOptions)).withConfig({
117
+ runName: "trim_messages",
118
+ });
117
119
  }
118
120
  }
119
121
  exports.trimMessages = trimMessages;
@@ -256,17 +258,19 @@ async function _firstMaxTokens(messages, options) {
256
258
  }
257
259
  async function _lastMaxTokens(messages, options) {
258
260
  const { allowPartial = false, includeSystem = false, endOn, startOn, ...rest } = options;
261
+ // Create a copy of messages to avoid mutation
262
+ let messagesCopy = [...messages];
259
263
  if (endOn) {
260
264
  const endOnArr = Array.isArray(endOn) ? endOn : [endOn];
261
- while (messages &&
262
- !_isMessageType(messages[messages.length - 1], endOnArr)) {
263
- messages.pop();
265
+ while (messagesCopy.length > 0 &&
266
+ !_isMessageType(messagesCopy[messagesCopy.length - 1], endOnArr)) {
267
+ messagesCopy = messagesCopy.slice(0, -1);
264
268
  }
265
269
  }
266
- const swappedSystem = includeSystem && messages[0]._getType() === "system";
270
+ const swappedSystem = includeSystem && messagesCopy[0]?._getType() === "system";
267
271
  let reversed_ = swappedSystem
268
- ? messages.slice(0, 1).concat(messages.slice(1).reverse())
269
- : messages.reverse();
272
+ ? messagesCopy.slice(0, 1).concat(messagesCopy.slice(1).reverse())
273
+ : messagesCopy.reverse();
270
274
  reversed_ = await _firstMaxTokens(reversed_, {
271
275
  ...rest,
272
276
  partialStrategy: allowPartial ? "last" : undefined,
@@ -76,7 +76,7 @@ function _mergeMessageRuns(messages) {
76
76
  }
77
77
  const merged = [];
78
78
  for (const msg of messages) {
79
- const curr = msg; // Create a shallow copy of the message
79
+ const curr = msg;
80
80
  const last = merged.pop();
81
81
  if (!last) {
82
82
  merged.push(curr);
@@ -108,7 +108,9 @@ export function trimMessages(messagesOrOptions, options) {
108
108
  }
109
109
  else {
110
110
  const trimmerOptions = messagesOrOptions;
111
- return RunnableLambda.from((input) => _trimMessagesHelper(input, trimmerOptions));
111
+ return RunnableLambda.from((input) => _trimMessagesHelper(input, trimmerOptions)).withConfig({
112
+ runName: "trim_messages",
113
+ });
112
114
  }
113
115
  }
114
116
  async function _trimMessagesHelper(messages, options) {
@@ -250,17 +252,19 @@ async function _firstMaxTokens(messages, options) {
250
252
  }
251
253
  async function _lastMaxTokens(messages, options) {
252
254
  const { allowPartial = false, includeSystem = false, endOn, startOn, ...rest } = options;
255
+ // Create a copy of messages to avoid mutation
256
+ let messagesCopy = [...messages];
253
257
  if (endOn) {
254
258
  const endOnArr = Array.isArray(endOn) ? endOn : [endOn];
255
- while (messages &&
256
- !_isMessageType(messages[messages.length - 1], endOnArr)) {
257
- messages.pop();
259
+ while (messagesCopy.length > 0 &&
260
+ !_isMessageType(messagesCopy[messagesCopy.length - 1], endOnArr)) {
261
+ messagesCopy = messagesCopy.slice(0, -1);
258
262
  }
259
263
  }
260
- const swappedSystem = includeSystem && messages[0]._getType() === "system";
264
+ const swappedSystem = includeSystem && messagesCopy[0]?._getType() === "system";
261
265
  let reversed_ = swappedSystem
262
- ? messages.slice(0, 1).concat(messages.slice(1).reverse())
263
- : messages.reverse();
266
+ ? messagesCopy.slice(0, 1).concat(messagesCopy.slice(1).reverse())
267
+ : messagesCopy.reverse();
264
268
  reversed_ = await _firstMaxTokens(reversed_, {
265
269
  ...rest,
266
270
  partialStrategy: allowPartial ? "last" : undefined,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@langchain/core",
3
- "version": "0.3.30",
3
+ "version": "0.3.32",
4
4
  "description": "Core LangChain.js abstractions and schemas",
5
5
  "type": "module",
6
6
  "engines": {
@@ -38,7 +38,7 @@
38
38
  "camelcase": "6",
39
39
  "decamelize": "1.2.0",
40
40
  "js-tiktoken": "^1.0.12",
41
- "langsmith": "^0.2.8",
41
+ "langsmith": ">=0.2.8 <0.4.0",
42
42
  "mustache": "^4.2.0",
43
43
  "p-queue": "^6.6.2",
44
44
  "p-retry": "4",