1#![allow(clippy::new_without_default)]
3#![allow(clippy::needless_pass_by_value)]
4#![allow(clippy::too_many_arguments)]
5#![allow(unused_imports)]
6
7use fixer::message::Message;
8use fixer::fix_string::FIXString;
9use fixer::errors::MessageRejectErrorEnum;
10use fixer::session::session_id::SessionID;
11
12use rust_decimal::Decimal;
13
14
15use jiff::Timestamp;
16
17use crate::field;
18use crate::tag;
19
20pub struct PositionMaintenanceReport {
22 pub message: Message,
23}
24
25impl PositionMaintenanceReport {
26 pub fn new(pos_maint_rpt_id: field::PosMaintRptIDField, pos_trans_type: field::PosTransTypeField, pos_maint_action: field::PosMaintActionField, pos_maint_status: field::PosMaintStatusField, clearing_business_date: field::ClearingBusinessDateField) -> Self {
28 let mut msg = Message::new();
29 msg.header.set_field(tag::MSG_TYPE, FIXString::from("AM".to_string()));
30
31 msg.body.set_field(tag::POS_MAINT_RPT_ID, pos_maint_rpt_id.0);
32
33 msg.body.set_field(tag::POS_TRANS_TYPE, pos_trans_type.0);
34
35 msg.body.set_field(tag::POS_MAINT_ACTION, pos_maint_action.0);
36
37 msg.body.set_field(tag::POS_MAINT_STATUS, pos_maint_status.0);
38
39 msg.body.set_field(tag::CLEARING_BUSINESS_DATE, clearing_business_date.0);
40
41 Self { message: msg }
42 }
43
44 pub fn from_message(msg: Message) -> Self {
46 Self { message: msg }
47 }
48
49 pub fn to_message(self) -> Message {
51 self.message
52 }
53
54
55
56
57 pub fn set_account(&mut self, v: String) {
59 self.message.body.set_field(tag::ACCOUNT, FIXString::from(v));
60 }
61
62 pub fn get_account(&self) -> Result<String, MessageRejectErrorEnum> {
64 let mut fld = field::AccountField::new(String::new());
65 self.message.body.get_field(tag::ACCOUNT, &mut fld.0)?;
66 Ok(fld.value().to_string())
67 }
68
69
70 pub fn has_account(&self) -> bool {
72 self.message.body.has(tag::ACCOUNT)
73 }
74
75
76
77
78 pub fn set_account_type(&mut self, v: isize) {
80 self.message.body.set_field(tag::ACCOUNT_TYPE, fixer::fix_int::FIXInt::from(v));
81 }
82
83 pub fn get_account_type(&self) -> Result<isize, MessageRejectErrorEnum> {
85 let mut fld = field::AccountTypeField::new(0);
86 self.message.body.get_field(tag::ACCOUNT_TYPE, &mut fld.0)?;
87 Ok(fld.value())
88 }
89
90
91 pub fn has_account_type(&self) -> bool {
93 self.message.body.has(tag::ACCOUNT_TYPE)
94 }
95
96
97
98
99 pub fn set_acct_id_source(&mut self, v: isize) {
101 self.message.body.set_field(tag::ACCT_ID_SOURCE, fixer::fix_int::FIXInt::from(v));
102 }
103
104 pub fn get_acct_id_source(&self) -> Result<isize, MessageRejectErrorEnum> {
106 let mut fld = field::AcctIDSourceField::new(0);
107 self.message.body.get_field(tag::ACCT_ID_SOURCE, &mut fld.0)?;
108 Ok(fld.value())
109 }
110
111
112 pub fn has_acct_id_source(&self) -> bool {
114 self.message.body.has(tag::ACCT_ID_SOURCE)
115 }
116
117
118
119
120 pub fn set_adjustment_type(&mut self, v: isize) {
122 self.message.body.set_field(tag::ADJUSTMENT_TYPE, fixer::fix_int::FIXInt::from(v));
123 }
124
125 pub fn get_adjustment_type(&self) -> Result<isize, MessageRejectErrorEnum> {
127 let mut fld = field::AdjustmentTypeField::new(0);
128 self.message.body.get_field(tag::ADJUSTMENT_TYPE, &mut fld.0)?;
129 Ok(fld.value())
130 }
131
132
133 pub fn has_adjustment_type(&self) -> bool {
135 self.message.body.has(tag::ADJUSTMENT_TYPE)
136 }
137
138
139
140
141 pub fn set_attachment_point(&mut self, val: Decimal, scale: i32) {
143 self.message.body.set_field(tag::ATTACHMENT_POINT, fixer::fix_decimal::FIXDecimal { decimal: val, scale });
144 }
145
146 pub fn get_attachment_point(&self) -> Result<Decimal, MessageRejectErrorEnum> {
148 let mut fld = field::AttachmentPointField::new(Decimal::ZERO, 0);
149 self.message.body.get_field(tag::ATTACHMENT_POINT, &mut fld.0)?;
150 Ok(fld.value())
151 }
152
153
154 pub fn has_attachment_point(&self) -> bool {
156 self.message.body.has(tag::ATTACHMENT_POINT)
157 }
158
159
160
161
162 pub fn set_cfi_code(&mut self, v: String) {
164 self.message.body.set_field(tag::CFI_CODE, FIXString::from(v));
165 }
166
167 pub fn get_cfi_code(&self) -> Result<String, MessageRejectErrorEnum> {
169 let mut fld = field::CFICodeField::new(String::new());
170 self.message.body.get_field(tag::CFI_CODE, &mut fld.0)?;
171 Ok(fld.value().to_string())
172 }
173
174
175 pub fn has_cfi_code(&self) -> bool {
177 self.message.body.has(tag::CFI_CODE)
178 }
179
180
181
182
183 pub fn set_cp_program(&mut self, v: isize) {
185 self.message.body.set_field(tag::CP_PROGRAM, fixer::fix_int::FIXInt::from(v));
186 }
187
188 pub fn get_cp_program(&self) -> Result<isize, MessageRejectErrorEnum> {
190 let mut fld = field::CPProgramField::new(0);
191 self.message.body.get_field(tag::CP_PROGRAM, &mut fld.0)?;
192 Ok(fld.value())
193 }
194
195
196 pub fn has_cp_program(&self) -> bool {
198 self.message.body.has(tag::CP_PROGRAM)
199 }
200
201
202
203
204 pub fn set_cp_reg_type(&mut self, v: String) {
206 self.message.body.set_field(tag::CP_REG_TYPE, FIXString::from(v));
207 }
208
209 pub fn get_cp_reg_type(&self) -> Result<String, MessageRejectErrorEnum> {
211 let mut fld = field::CPRegTypeField::new(String::new());
212 self.message.body.get_field(tag::CP_REG_TYPE, &mut fld.0)?;
213 Ok(fld.value().to_string())
214 }
215
216
217 pub fn has_cp_reg_type(&self) -> bool {
219 self.message.body.has(tag::CP_REG_TYPE)
220 }
221
222
223
224
225 pub fn set_cap_price(&mut self, val: Decimal, scale: i32) {
227 self.message.body.set_field(tag::CAP_PRICE, fixer::fix_decimal::FIXDecimal { decimal: val, scale });
228 }
229
230 pub fn get_cap_price(&self) -> Result<Decimal, MessageRejectErrorEnum> {
232 let mut fld = field::CapPriceField::new(Decimal::ZERO, 0);
233 self.message.body.get_field(tag::CAP_PRICE, &mut fld.0)?;
234 Ok(fld.value())
235 }
236
237
238 pub fn has_cap_price(&self) -> bool {
240 self.message.body.has(tag::CAP_PRICE)
241 }
242
243
244
245
246 pub fn set_clearing_business_date(&mut self, v: String) {
248 self.message.body.set_field(tag::CLEARING_BUSINESS_DATE, FIXString::from(v));
249 }
250
251 pub fn get_clearing_business_date(&self) -> Result<String, MessageRejectErrorEnum> {
253 let mut fld = field::ClearingBusinessDateField::new(String::new());
254 self.message.body.get_field(tag::CLEARING_BUSINESS_DATE, &mut fld.0)?;
255 Ok(fld.value().to_string())
256 }
257
258
259 pub fn has_clearing_business_date(&self) -> bool {
261 self.message.body.has(tag::CLEARING_BUSINESS_DATE)
262 }
263
264
265
266
267 pub fn set_contract_multiplier(&mut self, val: Decimal, scale: i32) {
269 self.message.body.set_field(tag::CONTRACT_MULTIPLIER, fixer::fix_decimal::FIXDecimal { decimal: val, scale });
270 }
271
272 pub fn get_contract_multiplier(&self) -> Result<Decimal, MessageRejectErrorEnum> {
274 let mut fld = field::ContractMultiplierField::new(Decimal::ZERO, 0);
275 self.message.body.get_field(tag::CONTRACT_MULTIPLIER, &mut fld.0)?;
276 Ok(fld.value())
277 }
278
279
280 pub fn has_contract_multiplier(&self) -> bool {
282 self.message.body.has(tag::CONTRACT_MULTIPLIER)
283 }
284
285
286
287
288 pub fn set_contract_multiplier_unit(&mut self, v: isize) {
290 self.message.body.set_field(tag::CONTRACT_MULTIPLIER_UNIT, fixer::fix_int::FIXInt::from(v));
291 }
292
293 pub fn get_contract_multiplier_unit(&self) -> Result<isize, MessageRejectErrorEnum> {
295 let mut fld = field::ContractMultiplierUnitField::new(0);
296 self.message.body.get_field(tag::CONTRACT_MULTIPLIER_UNIT, &mut fld.0)?;
297 Ok(fld.value())
298 }
299
300
301 pub fn has_contract_multiplier_unit(&self) -> bool {
303 self.message.body.has(tag::CONTRACT_MULTIPLIER_UNIT)
304 }
305
306
307
308
309 pub fn set_contract_settl_month(&mut self, v: String) {
311 self.message.body.set_field(tag::CONTRACT_SETTL_MONTH, FIXString::from(v));
312 }
313
314 pub fn get_contract_settl_month(&self) -> Result<String, MessageRejectErrorEnum> {
316 let mut fld = field::ContractSettlMonthField::new(String::new());
317 self.message.body.get_field(tag::CONTRACT_SETTL_MONTH, &mut fld.0)?;
318 Ok(fld.value().to_string())
319 }
320
321
322 pub fn has_contract_settl_month(&self) -> bool {
324 self.message.body.has(tag::CONTRACT_SETTL_MONTH)
325 }
326
327
328
329
330 pub fn set_contrary_instruction_indicator(&mut self, v: bool) {
332 self.message.body.set_field(tag::CONTRARY_INSTRUCTION_INDICATOR, fixer::fix_boolean::FIXBoolean::from(v));
333 }
334
335 pub fn get_contrary_instruction_indicator(&self) -> Result<bool, MessageRejectErrorEnum> {
337 let mut fld = field::ContraryInstructionIndicatorField::new(false);
338 self.message.body.get_field(tag::CONTRARY_INSTRUCTION_INDICATOR, &mut fld.0)?;
339 Ok(fld.value())
340 }
341
342
343 pub fn has_contrary_instruction_indicator(&self) -> bool {
345 self.message.body.has(tag::CONTRARY_INSTRUCTION_INDICATOR)
346 }
347
348
349
350
351 pub fn set_country_of_issue(&mut self, v: String) {
353 self.message.body.set_field(tag::COUNTRY_OF_ISSUE, FIXString::from(v));
354 }
355
356 pub fn get_country_of_issue(&self) -> Result<String, MessageRejectErrorEnum> {
358 let mut fld = field::CountryOfIssueField::new(String::new());
359 self.message.body.get_field(tag::COUNTRY_OF_ISSUE, &mut fld.0)?;
360 Ok(fld.value().to_string())
361 }
362
363
364 pub fn has_country_of_issue(&self) -> bool {
366 self.message.body.has(tag::COUNTRY_OF_ISSUE)
367 }
368
369
370
371
372 pub fn set_coupon_payment_date(&mut self, v: String) {
374 self.message.body.set_field(tag::COUPON_PAYMENT_DATE, FIXString::from(v));
375 }
376
377 pub fn get_coupon_payment_date(&self) -> Result<String, MessageRejectErrorEnum> {
379 let mut fld = field::CouponPaymentDateField::new(String::new());
380 self.message.body.get_field(tag::COUPON_PAYMENT_DATE, &mut fld.0)?;
381 Ok(fld.value().to_string())
382 }
383
384
385 pub fn has_coupon_payment_date(&self) -> bool {
387 self.message.body.has(tag::COUPON_PAYMENT_DATE)
388 }
389
390
391
392
393 pub fn set_coupon_rate(&mut self, val: Decimal, scale: i32) {
395 self.message.body.set_field(tag::COUPON_RATE, fixer::fix_decimal::FIXDecimal { decimal: val, scale });
396 }
397
398 pub fn get_coupon_rate(&self) -> Result<Decimal, MessageRejectErrorEnum> {
400 let mut fld = field::CouponRateField::new(Decimal::ZERO, 0);
401 self.message.body.get_field(tag::COUPON_RATE, &mut fld.0)?;
402 Ok(fld.value())
403 }
404
405
406 pub fn has_coupon_rate(&self) -> bool {
408 self.message.body.has(tag::COUPON_RATE)
409 }
410
411
412
413
414 pub fn set_credit_rating(&mut self, v: String) {
416 self.message.body.set_field(tag::CREDIT_RATING, FIXString::from(v));
417 }
418
419 pub fn get_credit_rating(&self) -> Result<String, MessageRejectErrorEnum> {
421 let mut fld = field::CreditRatingField::new(String::new());
422 self.message.body.get_field(tag::CREDIT_RATING, &mut fld.0)?;
423 Ok(fld.value().to_string())
424 }
425
426
427 pub fn has_credit_rating(&self) -> bool {
429 self.message.body.has(tag::CREDIT_RATING)
430 }
431
432
433
434
435 pub fn set_currency(&mut self, v: String) {
437 self.message.body.set_field(tag::CURRENCY, FIXString::from(v));
438 }
439
440 pub fn get_currency(&self) -> Result<String, MessageRejectErrorEnum> {
442 let mut fld = field::CurrencyField::new(String::new());
443 self.message.body.get_field(tag::CURRENCY, &mut fld.0)?;
444 Ok(fld.value().to_string())
445 }
446
447
448 pub fn has_currency(&self) -> bool {
450 self.message.body.has(tag::CURRENCY)
451 }
452
453
454
455
456 pub fn set_dated_date(&mut self, v: String) {
458 self.message.body.set_field(tag::DATED_DATE, FIXString::from(v));
459 }
460
461 pub fn get_dated_date(&self) -> Result<String, MessageRejectErrorEnum> {
463 let mut fld = field::DatedDateField::new(String::new());
464 self.message.body.get_field(tag::DATED_DATE, &mut fld.0)?;
465 Ok(fld.value().to_string())
466 }
467
468
469 pub fn has_dated_date(&self) -> bool {
471 self.message.body.has(tag::DATED_DATE)
472 }
473
474
475
476
477 pub fn set_detachment_point(&mut self, val: Decimal, scale: i32) {
479 self.message.body.set_field(tag::DETACHMENT_POINT, fixer::fix_decimal::FIXDecimal { decimal: val, scale });
480 }
481
482 pub fn get_detachment_point(&self) -> Result<Decimal, MessageRejectErrorEnum> {
484 let mut fld = field::DetachmentPointField::new(Decimal::ZERO, 0);
485 self.message.body.get_field(tag::DETACHMENT_POINT, &mut fld.0)?;
486 Ok(fld.value())
487 }
488
489
490 pub fn has_detachment_point(&self) -> bool {
492 self.message.body.has(tag::DETACHMENT_POINT)
493 }
494
495
496
497
498 pub fn set_encoded_issuer(&mut self, v: String) {
500 self.message.body.set_field(tag::ENCODED_ISSUER, FIXString::from(v));
501 }
502
503 pub fn get_encoded_issuer(&self) -> Result<String, MessageRejectErrorEnum> {
505 let mut fld = field::EncodedIssuerField::new(String::new());
506 self.message.body.get_field(tag::ENCODED_ISSUER, &mut fld.0)?;
507 Ok(fld.value().to_string())
508 }
509
510
511 pub fn has_encoded_issuer(&self) -> bool {
513 self.message.body.has(tag::ENCODED_ISSUER)
514 }
515
516
517
518
519 pub fn set_encoded_issuer_len(&mut self, v: isize) {
521 self.message.body.set_field(tag::ENCODED_ISSUER_LEN, fixer::fix_int::FIXInt::from(v));
522 }
523
524 pub fn get_encoded_issuer_len(&self) -> Result<isize, MessageRejectErrorEnum> {
526 let mut fld = field::EncodedIssuerLenField::new(0);
527 self.message.body.get_field(tag::ENCODED_ISSUER_LEN, &mut fld.0)?;
528 Ok(fld.value())
529 }
530
531
532 pub fn has_encoded_issuer_len(&self) -> bool {
534 self.message.body.has(tag::ENCODED_ISSUER_LEN)
535 }
536
537
538
539
540 pub fn set_encoded_security_desc(&mut self, v: String) {
542 self.message.body.set_field(tag::ENCODED_SECURITY_DESC, FIXString::from(v));
543 }
544
545 pub fn get_encoded_security_desc(&self) -> Result<String, MessageRejectErrorEnum> {
547 let mut fld = field::EncodedSecurityDescField::new(String::new());
548 self.message.body.get_field(tag::ENCODED_SECURITY_DESC, &mut fld.0)?;
549 Ok(fld.value().to_string())
550 }
551
552
553 pub fn has_encoded_security_desc(&self) -> bool {
555 self.message.body.has(tag::ENCODED_SECURITY_DESC)
556 }
557
558
559
560
561 pub fn set_encoded_security_desc_len(&mut self, v: isize) {
563 self.message.body.set_field(tag::ENCODED_SECURITY_DESC_LEN, fixer::fix_int::FIXInt::from(v));
564 }
565
566 pub fn get_encoded_security_desc_len(&self) -> Result<isize, MessageRejectErrorEnum> {
568 let mut fld = field::EncodedSecurityDescLenField::new(0);
569 self.message.body.get_field(tag::ENCODED_SECURITY_DESC_LEN, &mut fld.0)?;
570 Ok(fld.value())
571 }
572
573
574 pub fn has_encoded_security_desc_len(&self) -> bool {
576 self.message.body.has(tag::ENCODED_SECURITY_DESC_LEN)
577 }
578
579
580
581
582 pub fn set_encoded_text(&mut self, v: String) {
584 self.message.body.set_field(tag::ENCODED_TEXT, FIXString::from(v));
585 }
586
587 pub fn get_encoded_text(&self) -> Result<String, MessageRejectErrorEnum> {
589 let mut fld = field::EncodedTextField::new(String::new());
590 self.message.body.get_field(tag::ENCODED_TEXT, &mut fld.0)?;
591 Ok(fld.value().to_string())
592 }
593
594
595 pub fn has_encoded_text(&self) -> bool {
597 self.message.body.has(tag::ENCODED_TEXT)
598 }
599
600
601
602
603 pub fn set_encoded_text_len(&mut self, v: isize) {
605 self.message.body.set_field(tag::ENCODED_TEXT_LEN, fixer::fix_int::FIXInt::from(v));
606 }
607
608 pub fn get_encoded_text_len(&self) -> Result<isize, MessageRejectErrorEnum> {
610 let mut fld = field::EncodedTextLenField::new(0);
611 self.message.body.get_field(tag::ENCODED_TEXT_LEN, &mut fld.0)?;
612 Ok(fld.value())
613 }
614
615
616 pub fn has_encoded_text_len(&self) -> bool {
618 self.message.body.has(tag::ENCODED_TEXT_LEN)
619 }
620
621
622
623
624 pub fn set_exercise_style(&mut self, v: isize) {
626 self.message.body.set_field(tag::EXERCISE_STYLE, fixer::fix_int::FIXInt::from(v));
627 }
628
629 pub fn get_exercise_style(&self) -> Result<isize, MessageRejectErrorEnum> {
631 let mut fld = field::ExerciseStyleField::new(0);
632 self.message.body.get_field(tag::EXERCISE_STYLE, &mut fld.0)?;
633 Ok(fld.value())
634 }
635
636
637 pub fn has_exercise_style(&self) -> bool {
639 self.message.body.has(tag::EXERCISE_STYLE)
640 }
641
642
643
644
645 pub fn set_factor(&mut self, val: Decimal, scale: i32) {
647 self.message.body.set_field(tag::FACTOR, fixer::fix_decimal::FIXDecimal { decimal: val, scale });
648 }
649
650 pub fn get_factor(&self) -> Result<Decimal, MessageRejectErrorEnum> {
652 let mut fld = field::FactorField::new(Decimal::ZERO, 0);
653 self.message.body.get_field(tag::FACTOR, &mut fld.0)?;
654 Ok(fld.value())
655 }
656
657
658 pub fn has_factor(&self) -> bool {
660 self.message.body.has(tag::FACTOR)
661 }
662
663
664
665
666 pub fn set_flex_product_eligibility_indicator(&mut self, v: bool) {
668 self.message.body.set_field(tag::FLEX_PRODUCT_ELIGIBILITY_INDICATOR, fixer::fix_boolean::FIXBoolean::from(v));
669 }
670
671 pub fn get_flex_product_eligibility_indicator(&self) -> Result<bool, MessageRejectErrorEnum> {
673 let mut fld = field::FlexProductEligibilityIndicatorField::new(false);
674 self.message.body.get_field(tag::FLEX_PRODUCT_ELIGIBILITY_INDICATOR, &mut fld.0)?;
675 Ok(fld.value())
676 }
677
678
679 pub fn has_flex_product_eligibility_indicator(&self) -> bool {
681 self.message.body.has(tag::FLEX_PRODUCT_ELIGIBILITY_INDICATOR)
682 }
683
684
685
686
687 pub fn set_flexible_indicator(&mut self, v: bool) {
689 self.message.body.set_field(tag::FLEXIBLE_INDICATOR, fixer::fix_boolean::FIXBoolean::from(v));
690 }
691
692 pub fn get_flexible_indicator(&self) -> Result<bool, MessageRejectErrorEnum> {
694 let mut fld = field::FlexibleIndicatorField::new(false);
695 self.message.body.get_field(tag::FLEXIBLE_INDICATOR, &mut fld.0)?;
696 Ok(fld.value())
697 }
698
699
700 pub fn has_flexible_indicator(&self) -> bool {
702 self.message.body.has(tag::FLEXIBLE_INDICATOR)
703 }
704
705
706
707
708 pub fn set_floor_price(&mut self, val: Decimal, scale: i32) {
710 self.message.body.set_field(tag::FLOOR_PRICE, fixer::fix_decimal::FIXDecimal { decimal: val, scale });
711 }
712
713 pub fn get_floor_price(&self) -> Result<Decimal, MessageRejectErrorEnum> {
715 let mut fld = field::FloorPriceField::new(Decimal::ZERO, 0);
716 self.message.body.get_field(tag::FLOOR_PRICE, &mut fld.0)?;
717 Ok(fld.value())
718 }
719
720
721 pub fn has_floor_price(&self) -> bool {
723 self.message.body.has(tag::FLOOR_PRICE)
724 }
725
726
727
728
729 pub fn set_flow_schedule_type(&mut self, v: isize) {
731 self.message.body.set_field(tag::FLOW_SCHEDULE_TYPE, fixer::fix_int::FIXInt::from(v));
732 }
733
734 pub fn get_flow_schedule_type(&self) -> Result<isize, MessageRejectErrorEnum> {
736 let mut fld = field::FlowScheduleTypeField::new(0);
737 self.message.body.get_field(tag::FLOW_SCHEDULE_TYPE, &mut fld.0)?;
738 Ok(fld.value())
739 }
740
741
742 pub fn has_flow_schedule_type(&self) -> bool {
744 self.message.body.has(tag::FLOW_SCHEDULE_TYPE)
745 }
746
747
748
749
750 pub fn set_instr_registry(&mut self, v: String) {
752 self.message.body.set_field(tag::INSTR_REGISTRY, FIXString::from(v));
753 }
754
755 pub fn get_instr_registry(&self) -> Result<String, MessageRejectErrorEnum> {
757 let mut fld = field::InstrRegistryField::new(String::new());
758 self.message.body.get_field(tag::INSTR_REGISTRY, &mut fld.0)?;
759 Ok(fld.value().to_string())
760 }
761
762
763 pub fn has_instr_registry(&self) -> bool {
765 self.message.body.has(tag::INSTR_REGISTRY)
766 }
767
768
769
770
771 pub fn set_instrmt_assignment_method(&mut self, v: String) {
773 self.message.body.set_field(tag::INSTRMT_ASSIGNMENT_METHOD, FIXString::from(v));
774 }
775
776 pub fn get_instrmt_assignment_method(&self) -> Result<String, MessageRejectErrorEnum> {
778 let mut fld = field::InstrmtAssignmentMethodField::new(String::new());
779 self.message.body.get_field(tag::INSTRMT_ASSIGNMENT_METHOD, &mut fld.0)?;
780 Ok(fld.value().to_string())
781 }
782
783
784 pub fn has_instrmt_assignment_method(&self) -> bool {
786 self.message.body.has(tag::INSTRMT_ASSIGNMENT_METHOD)
787 }
788
789
790
791
792 pub fn set_interest_accrual_date(&mut self, v: String) {
794 self.message.body.set_field(tag::INTEREST_ACCRUAL_DATE, FIXString::from(v));
795 }
796
797 pub fn get_interest_accrual_date(&self) -> Result<String, MessageRejectErrorEnum> {
799 let mut fld = field::InterestAccrualDateField::new(String::new());
800 self.message.body.get_field(tag::INTEREST_ACCRUAL_DATE, &mut fld.0)?;
801 Ok(fld.value().to_string())
802 }
803
804
805 pub fn has_interest_accrual_date(&self) -> bool {
807 self.message.body.has(tag::INTEREST_ACCRUAL_DATE)
808 }
809
810
811
812
813 pub fn set_issue_date(&mut self, v: String) {
815 self.message.body.set_field(tag::ISSUE_DATE, FIXString::from(v));
816 }
817
818 pub fn get_issue_date(&self) -> Result<String, MessageRejectErrorEnum> {
820 let mut fld = field::IssueDateField::new(String::new());
821 self.message.body.get_field(tag::ISSUE_DATE, &mut fld.0)?;
822 Ok(fld.value().to_string())
823 }
824
825
826 pub fn has_issue_date(&self) -> bool {
828 self.message.body.has(tag::ISSUE_DATE)
829 }
830
831
832
833
834 pub fn set_issuer(&mut self, v: String) {
836 self.message.body.set_field(tag::ISSUER, FIXString::from(v));
837 }
838
839 pub fn get_issuer(&self) -> Result<String, MessageRejectErrorEnum> {
841 let mut fld = field::IssuerField::new(String::new());
842 self.message.body.get_field(tag::ISSUER, &mut fld.0)?;
843 Ok(fld.value().to_string())
844 }
845
846
847 pub fn has_issuer(&self) -> bool {
849 self.message.body.has(tag::ISSUER)
850 }
851
852
853
854
855 pub fn set_list_method(&mut self, v: isize) {
857 self.message.body.set_field(tag::LIST_METHOD, fixer::fix_int::FIXInt::from(v));
858 }
859
860 pub fn get_list_method(&self) -> Result<isize, MessageRejectErrorEnum> {
862 let mut fld = field::ListMethodField::new(0);
863 self.message.body.get_field(tag::LIST_METHOD, &mut fld.0)?;
864 Ok(fld.value())
865 }
866
867
868 pub fn has_list_method(&self) -> bool {
870 self.message.body.has(tag::LIST_METHOD)
871 }
872
873
874
875
876 pub fn set_locale_of_issue(&mut self, v: String) {
878 self.message.body.set_field(tag::LOCALE_OF_ISSUE, FIXString::from(v));
879 }
880
881 pub fn get_locale_of_issue(&self) -> Result<String, MessageRejectErrorEnum> {
883 let mut fld = field::LocaleOfIssueField::new(String::new());
884 self.message.body.get_field(tag::LOCALE_OF_ISSUE, &mut fld.0)?;
885 Ok(fld.value().to_string())
886 }
887
888
889 pub fn has_locale_of_issue(&self) -> bool {
891 self.message.body.has(tag::LOCALE_OF_ISSUE)
892 }
893
894
895
896
897 pub fn set_maturity_date(&mut self, v: String) {
899 self.message.body.set_field(tag::MATURITY_DATE, FIXString::from(v));
900 }
901
902 pub fn get_maturity_date(&self) -> Result<String, MessageRejectErrorEnum> {
904 let mut fld = field::MaturityDateField::new(String::new());
905 self.message.body.get_field(tag::MATURITY_DATE, &mut fld.0)?;
906 Ok(fld.value().to_string())
907 }
908
909
910 pub fn has_maturity_date(&self) -> bool {
912 self.message.body.has(tag::MATURITY_DATE)
913 }
914
915
916
917
918 pub fn set_maturity_month_year(&mut self, v: String) {
920 self.message.body.set_field(tag::MATURITY_MONTH_YEAR, FIXString::from(v));
921 }
922
923 pub fn get_maturity_month_year(&self) -> Result<String, MessageRejectErrorEnum> {
925 let mut fld = field::MaturityMonthYearField::new(String::new());
926 self.message.body.get_field(tag::MATURITY_MONTH_YEAR, &mut fld.0)?;
927 Ok(fld.value().to_string())
928 }
929
930
931 pub fn has_maturity_month_year(&self) -> bool {
933 self.message.body.has(tag::MATURITY_MONTH_YEAR)
934 }
935
936
937
938
939 pub fn set_maturity_time(&mut self, v: String) {
941 self.message.body.set_field(tag::MATURITY_TIME, FIXString::from(v));
942 }
943
944 pub fn get_maturity_time(&self) -> Result<String, MessageRejectErrorEnum> {
946 let mut fld = field::MaturityTimeField::new(String::new());
947 self.message.body.get_field(tag::MATURITY_TIME, &mut fld.0)?;
948 Ok(fld.value().to_string())
949 }
950
951
952 pub fn has_maturity_time(&self) -> bool {
954 self.message.body.has(tag::MATURITY_TIME)
955 }
956
957
958
959
960 pub fn set_min_price_increment(&mut self, val: Decimal, scale: i32) {
962 self.message.body.set_field(tag::MIN_PRICE_INCREMENT, fixer::fix_decimal::FIXDecimal { decimal: val, scale });
963 }
964
965 pub fn get_min_price_increment(&self) -> Result<Decimal, MessageRejectErrorEnum> {
967 let mut fld = field::MinPriceIncrementField::new(Decimal::ZERO, 0);
968 self.message.body.get_field(tag::MIN_PRICE_INCREMENT, &mut fld.0)?;
969 Ok(fld.value())
970 }
971
972
973 pub fn has_min_price_increment(&self) -> bool {
975 self.message.body.has(tag::MIN_PRICE_INCREMENT)
976 }
977
978
979
980
981 pub fn set_min_price_increment_amount(&mut self, val: Decimal, scale: i32) {
983 self.message.body.set_field(tag::MIN_PRICE_INCREMENT_AMOUNT, fixer::fix_decimal::FIXDecimal { decimal: val, scale });
984 }
985
986 pub fn get_min_price_increment_amount(&self) -> Result<Decimal, MessageRejectErrorEnum> {
988 let mut fld = field::MinPriceIncrementAmountField::new(Decimal::ZERO, 0);
989 self.message.body.get_field(tag::MIN_PRICE_INCREMENT_AMOUNT, &mut fld.0)?;
990 Ok(fld.value())
991 }
992
993
994 pub fn has_min_price_increment_amount(&self) -> bool {
996 self.message.body.has(tag::MIN_PRICE_INCREMENT_AMOUNT)
997 }
998
999
1000
1001
1002 pub fn set_nt_position_limit(&mut self, v: isize) {
1004 self.message.body.set_field(tag::NT_POSITION_LIMIT, fixer::fix_int::FIXInt::from(v));
1005 }
1006
1007 pub fn get_nt_position_limit(&self) -> Result<isize, MessageRejectErrorEnum> {
1009 let mut fld = field::NTPositionLimitField::new(0);
1010 self.message.body.get_field(tag::NT_POSITION_LIMIT, &mut fld.0)?;
1011 Ok(fld.value())
1012 }
1013
1014
1015 pub fn has_nt_position_limit(&self) -> bool {
1017 self.message.body.has(tag::NT_POSITION_LIMIT)
1018 }
1019
1020
1021
1022
1023 pub fn set_no_complex_events(&mut self, v: isize) {
1025 self.message.body.set_field(tag::NO_COMPLEX_EVENTS, fixer::fix_int::FIXInt::from(v));
1026 }
1027
1028 pub fn get_no_complex_events(&self) -> Result<isize, MessageRejectErrorEnum> {
1030 let mut fld = field::NoComplexEventsField::new(0);
1031 self.message.body.get_field(tag::NO_COMPLEX_EVENTS, &mut fld.0)?;
1032 Ok(fld.value())
1033 }
1034
1035
1036 pub fn has_no_complex_events(&self) -> bool {
1038 self.message.body.has(tag::NO_COMPLEX_EVENTS)
1039 }
1040
1041
1042
1043
1044 pub fn set_no_events(&mut self, v: isize) {
1046 self.message.body.set_field(tag::NO_EVENTS, fixer::fix_int::FIXInt::from(v));
1047 }
1048
1049 pub fn get_no_events(&self) -> Result<isize, MessageRejectErrorEnum> {
1051 let mut fld = field::NoEventsField::new(0);
1052 self.message.body.get_field(tag::NO_EVENTS, &mut fld.0)?;
1053 Ok(fld.value())
1054 }
1055
1056
1057 pub fn has_no_events(&self) -> bool {
1059 self.message.body.has(tag::NO_EVENTS)
1060 }
1061
1062
1063
1064
1065 pub fn set_no_instrument_parties(&mut self, v: isize) {
1067 self.message.body.set_field(tag::NO_INSTRUMENT_PARTIES, fixer::fix_int::FIXInt::from(v));
1068 }
1069
1070 pub fn get_no_instrument_parties(&self) -> Result<isize, MessageRejectErrorEnum> {
1072 let mut fld = field::NoInstrumentPartiesField::new(0);
1073 self.message.body.get_field(tag::NO_INSTRUMENT_PARTIES, &mut fld.0)?;
1074 Ok(fld.value())
1075 }
1076
1077
1078 pub fn has_no_instrument_parties(&self) -> bool {
1080 self.message.body.has(tag::NO_INSTRUMENT_PARTIES)
1081 }
1082
1083
1084
1085
1086 pub fn set_no_legs(&mut self, v: isize) {
1088 self.message.body.set_field(tag::NO_LEGS, fixer::fix_int::FIXInt::from(v));
1089 }
1090
1091 pub fn get_no_legs(&self) -> Result<isize, MessageRejectErrorEnum> {
1093 let mut fld = field::NoLegsField::new(0);
1094 self.message.body.get_field(tag::NO_LEGS, &mut fld.0)?;
1095 Ok(fld.value())
1096 }
1097
1098
1099 pub fn has_no_legs(&self) -> bool {
1101 self.message.body.has(tag::NO_LEGS)
1102 }
1103
1104
1105
1106
1107 pub fn set_no_party_i_ds(&mut self, v: isize) {
1109 self.message.body.set_field(tag::NO_PARTY_I_DS, fixer::fix_int::FIXInt::from(v));
1110 }
1111
1112 pub fn get_no_party_i_ds(&self) -> Result<isize, MessageRejectErrorEnum> {
1114 let mut fld = field::NoPartyIDsField::new(0);
1115 self.message.body.get_field(tag::NO_PARTY_I_DS, &mut fld.0)?;
1116 Ok(fld.value())
1117 }
1118
1119
1120 pub fn has_no_party_i_ds(&self) -> bool {
1122 self.message.body.has(tag::NO_PARTY_I_DS)
1123 }
1124
1125
1126
1127
1128 pub fn set_no_pos_amt(&mut self, v: isize) {
1130 self.message.body.set_field(tag::NO_POS_AMT, fixer::fix_int::FIXInt::from(v));
1131 }
1132
1133 pub fn get_no_pos_amt(&self) -> Result<isize, MessageRejectErrorEnum> {
1135 let mut fld = field::NoPosAmtField::new(0);
1136 self.message.body.get_field(tag::NO_POS_AMT, &mut fld.0)?;
1137 Ok(fld.value())
1138 }
1139
1140
1141 pub fn has_no_pos_amt(&self) -> bool {
1143 self.message.body.has(tag::NO_POS_AMT)
1144 }
1145
1146
1147
1148
1149 pub fn set_no_positions(&mut self, v: isize) {
1151 self.message.body.set_field(tag::NO_POSITIONS, fixer::fix_int::FIXInt::from(v));
1152 }
1153
1154 pub fn get_no_positions(&self) -> Result<isize, MessageRejectErrorEnum> {
1156 let mut fld = field::NoPositionsField::new(0);
1157 self.message.body.get_field(tag::NO_POSITIONS, &mut fld.0)?;
1158 Ok(fld.value())
1159 }
1160
1161
1162 pub fn has_no_positions(&self) -> bool {
1164 self.message.body.has(tag::NO_POSITIONS)
1165 }
1166
1167
1168
1169
1170 pub fn set_no_security_alt_id(&mut self, v: isize) {
1172 self.message.body.set_field(tag::NO_SECURITY_ALT_ID, fixer::fix_int::FIXInt::from(v));
1173 }
1174
1175 pub fn get_no_security_alt_id(&self) -> Result<isize, MessageRejectErrorEnum> {
1177 let mut fld = field::NoSecurityAltIDField::new(0);
1178 self.message.body.get_field(tag::NO_SECURITY_ALT_ID, &mut fld.0)?;
1179 Ok(fld.value())
1180 }
1181
1182
1183 pub fn has_no_security_alt_id(&self) -> bool {
1185 self.message.body.has(tag::NO_SECURITY_ALT_ID)
1186 }
1187
1188
1189
1190
1191 pub fn set_no_trading_sessions(&mut self, v: isize) {
1193 self.message.body.set_field(tag::NO_TRADING_SESSIONS, fixer::fix_int::FIXInt::from(v));
1194 }
1195
1196 pub fn get_no_trading_sessions(&self) -> Result<isize, MessageRejectErrorEnum> {
1198 let mut fld = field::NoTradingSessionsField::new(0);
1199 self.message.body.get_field(tag::NO_TRADING_SESSIONS, &mut fld.0)?;
1200 Ok(fld.value())
1201 }
1202
1203
1204 pub fn has_no_trading_sessions(&self) -> bool {
1206 self.message.body.has(tag::NO_TRADING_SESSIONS)
1207 }
1208
1209
1210
1211
1212 pub fn set_no_underlyings(&mut self, v: isize) {
1214 self.message.body.set_field(tag::NO_UNDERLYINGS, fixer::fix_int::FIXInt::from(v));
1215 }
1216
1217 pub fn get_no_underlyings(&self) -> Result<isize, MessageRejectErrorEnum> {
1219 let mut fld = field::NoUnderlyingsField::new(0);
1220 self.message.body.get_field(tag::NO_UNDERLYINGS, &mut fld.0)?;
1221 Ok(fld.value())
1222 }
1223
1224
1225 pub fn has_no_underlyings(&self) -> bool {
1227 self.message.body.has(tag::NO_UNDERLYINGS)
1228 }
1229
1230
1231
1232
1233 pub fn set_notional_percentage_outstanding(&mut self, val: Decimal, scale: i32) {
1235 self.message.body.set_field(tag::NOTIONAL_PERCENTAGE_OUTSTANDING, fixer::fix_decimal::FIXDecimal { decimal: val, scale });
1236 }
1237
1238 pub fn get_notional_percentage_outstanding(&self) -> Result<Decimal, MessageRejectErrorEnum> {
1240 let mut fld = field::NotionalPercentageOutstandingField::new(Decimal::ZERO, 0);
1241 self.message.body.get_field(tag::NOTIONAL_PERCENTAGE_OUTSTANDING, &mut fld.0)?;
1242 Ok(fld.value())
1243 }
1244
1245
1246 pub fn has_notional_percentage_outstanding(&self) -> bool {
1248 self.message.body.has(tag::NOTIONAL_PERCENTAGE_OUTSTANDING)
1249 }
1250
1251
1252
1253
1254 pub fn set_opt_attribute(&mut self, v: String) {
1256 self.message.body.set_field(tag::OPT_ATTRIBUTE, FIXString::from(v));
1257 }
1258
1259 pub fn get_opt_attribute(&self) -> Result<String, MessageRejectErrorEnum> {
1261 let mut fld = field::OptAttributeField::new(String::new());
1262 self.message.body.get_field(tag::OPT_ATTRIBUTE, &mut fld.0)?;
1263 Ok(fld.value().to_string())
1264 }
1265
1266
1267 pub fn has_opt_attribute(&self) -> bool {
1269 self.message.body.has(tag::OPT_ATTRIBUTE)
1270 }
1271
1272
1273
1274
1275 pub fn set_opt_payout_amount(&mut self, val: Decimal, scale: i32) {
1277 self.message.body.set_field(tag::OPT_PAYOUT_AMOUNT, fixer::fix_decimal::FIXDecimal { decimal: val, scale });
1278 }
1279
1280 pub fn get_opt_payout_amount(&self) -> Result<Decimal, MessageRejectErrorEnum> {
1282 let mut fld = field::OptPayoutAmountField::new(Decimal::ZERO, 0);
1283 self.message.body.get_field(tag::OPT_PAYOUT_AMOUNT, &mut fld.0)?;
1284 Ok(fld.value())
1285 }
1286
1287
1288 pub fn has_opt_payout_amount(&self) -> bool {
1290 self.message.body.has(tag::OPT_PAYOUT_AMOUNT)
1291 }
1292
1293
1294
1295
1296 pub fn set_opt_payout_type(&mut self, v: isize) {
1298 self.message.body.set_field(tag::OPT_PAYOUT_TYPE, fixer::fix_int::FIXInt::from(v));
1299 }
1300
1301 pub fn get_opt_payout_type(&self) -> Result<isize, MessageRejectErrorEnum> {
1303 let mut fld = field::OptPayoutTypeField::new(0);
1304 self.message.body.get_field(tag::OPT_PAYOUT_TYPE, &mut fld.0)?;
1305 Ok(fld.value())
1306 }
1307
1308
1309 pub fn has_opt_payout_type(&self) -> bool {
1311 self.message.body.has(tag::OPT_PAYOUT_TYPE)
1312 }
1313
1314
1315
1316
1317 pub fn set_orig_pos_req_ref_id(&mut self, v: String) {
1319 self.message.body.set_field(tag::ORIG_POS_REQ_REF_ID, FIXString::from(v));
1320 }
1321
1322 pub fn get_orig_pos_req_ref_id(&self) -> Result<String, MessageRejectErrorEnum> {
1324 let mut fld = field::OrigPosReqRefIDField::new(String::new());
1325 self.message.body.get_field(tag::ORIG_POS_REQ_REF_ID, &mut fld.0)?;
1326 Ok(fld.value().to_string())
1327 }
1328
1329
1330 pub fn has_orig_pos_req_ref_id(&self) -> bool {
1332 self.message.body.has(tag::ORIG_POS_REQ_REF_ID)
1333 }
1334
1335
1336
1337
1338 pub fn set_original_notional_percentage_outstanding(&mut self, val: Decimal, scale: i32) {
1340 self.message.body.set_field(tag::ORIGINAL_NOTIONAL_PERCENTAGE_OUTSTANDING, fixer::fix_decimal::FIXDecimal { decimal: val, scale });
1341 }
1342
1343 pub fn get_original_notional_percentage_outstanding(&self) -> Result<Decimal, MessageRejectErrorEnum> {
1345 let mut fld = field::OriginalNotionalPercentageOutstandingField::new(Decimal::ZERO, 0);
1346 self.message.body.get_field(tag::ORIGINAL_NOTIONAL_PERCENTAGE_OUTSTANDING, &mut fld.0)?;
1347 Ok(fld.value())
1348 }
1349
1350
1351 pub fn has_original_notional_percentage_outstanding(&self) -> bool {
1353 self.message.body.has(tag::ORIGINAL_NOTIONAL_PERCENTAGE_OUTSTANDING)
1354 }
1355
1356
1357
1358
1359 pub fn set_pool(&mut self, v: String) {
1361 self.message.body.set_field(tag::POOL, FIXString::from(v));
1362 }
1363
1364 pub fn get_pool(&self) -> Result<String, MessageRejectErrorEnum> {
1366 let mut fld = field::PoolField::new(String::new());
1367 self.message.body.get_field(tag::POOL, &mut fld.0)?;
1368 Ok(fld.value().to_string())
1369 }
1370
1371
1372 pub fn has_pool(&self) -> bool {
1374 self.message.body.has(tag::POOL)
1375 }
1376
1377
1378
1379
1380 pub fn set_pos_maint_action(&mut self, v: isize) {
1382 self.message.body.set_field(tag::POS_MAINT_ACTION, fixer::fix_int::FIXInt::from(v));
1383 }
1384
1385 pub fn get_pos_maint_action(&self) -> Result<isize, MessageRejectErrorEnum> {
1387 let mut fld = field::PosMaintActionField::new(0);
1388 self.message.body.get_field(tag::POS_MAINT_ACTION, &mut fld.0)?;
1389 Ok(fld.value())
1390 }
1391
1392
1393 pub fn has_pos_maint_action(&self) -> bool {
1395 self.message.body.has(tag::POS_MAINT_ACTION)
1396 }
1397
1398
1399
1400
1401 pub fn set_pos_maint_result(&mut self, v: isize) {
1403 self.message.body.set_field(tag::POS_MAINT_RESULT, fixer::fix_int::FIXInt::from(v));
1404 }
1405
1406 pub fn get_pos_maint_result(&self) -> Result<isize, MessageRejectErrorEnum> {
1408 let mut fld = field::PosMaintResultField::new(0);
1409 self.message.body.get_field(tag::POS_MAINT_RESULT, &mut fld.0)?;
1410 Ok(fld.value())
1411 }
1412
1413
1414 pub fn has_pos_maint_result(&self) -> bool {
1416 self.message.body.has(tag::POS_MAINT_RESULT)
1417 }
1418
1419
1420
1421
1422 pub fn set_pos_maint_rpt_id(&mut self, v: String) {
1424 self.message.body.set_field(tag::POS_MAINT_RPT_ID, FIXString::from(v));
1425 }
1426
1427 pub fn get_pos_maint_rpt_id(&self) -> Result<String, MessageRejectErrorEnum> {
1429 let mut fld = field::PosMaintRptIDField::new(String::new());
1430 self.message.body.get_field(tag::POS_MAINT_RPT_ID, &mut fld.0)?;
1431 Ok(fld.value().to_string())
1432 }
1433
1434
1435 pub fn has_pos_maint_rpt_id(&self) -> bool {
1437 self.message.body.has(tag::POS_MAINT_RPT_ID)
1438 }
1439
1440
1441
1442
1443 pub fn set_pos_maint_rpt_ref_id(&mut self, v: String) {
1445 self.message.body.set_field(tag::POS_MAINT_RPT_REF_ID, FIXString::from(v));
1446 }
1447
1448 pub fn get_pos_maint_rpt_ref_id(&self) -> Result<String, MessageRejectErrorEnum> {
1450 let mut fld = field::PosMaintRptRefIDField::new(String::new());
1451 self.message.body.get_field(tag::POS_MAINT_RPT_REF_ID, &mut fld.0)?;
1452 Ok(fld.value().to_string())
1453 }
1454
1455
1456 pub fn has_pos_maint_rpt_ref_id(&self) -> bool {
1458 self.message.body.has(tag::POS_MAINT_RPT_REF_ID)
1459 }
1460
1461
1462
1463
1464 pub fn set_pos_maint_status(&mut self, v: isize) {
1466 self.message.body.set_field(tag::POS_MAINT_STATUS, fixer::fix_int::FIXInt::from(v));
1467 }
1468
1469 pub fn get_pos_maint_status(&self) -> Result<isize, MessageRejectErrorEnum> {
1471 let mut fld = field::PosMaintStatusField::new(0);
1472 self.message.body.get_field(tag::POS_MAINT_STATUS, &mut fld.0)?;
1473 Ok(fld.value())
1474 }
1475
1476
1477 pub fn has_pos_maint_status(&self) -> bool {
1479 self.message.body.has(tag::POS_MAINT_STATUS)
1480 }
1481
1482
1483
1484
1485 pub fn set_pos_req_id(&mut self, v: String) {
1487 self.message.body.set_field(tag::POS_REQ_ID, FIXString::from(v));
1488 }
1489
1490 pub fn get_pos_req_id(&self) -> Result<String, MessageRejectErrorEnum> {
1492 let mut fld = field::PosReqIDField::new(String::new());
1493 self.message.body.get_field(tag::POS_REQ_ID, &mut fld.0)?;
1494 Ok(fld.value().to_string())
1495 }
1496
1497
1498 pub fn has_pos_req_id(&self) -> bool {
1500 self.message.body.has(tag::POS_REQ_ID)
1501 }
1502
1503
1504
1505
1506 pub fn set_pos_trans_type(&mut self, v: isize) {
1508 self.message.body.set_field(tag::POS_TRANS_TYPE, fixer::fix_int::FIXInt::from(v));
1509 }
1510
1511 pub fn get_pos_trans_type(&self) -> Result<isize, MessageRejectErrorEnum> {
1513 let mut fld = field::PosTransTypeField::new(0);
1514 self.message.body.get_field(tag::POS_TRANS_TYPE, &mut fld.0)?;
1515 Ok(fld.value())
1516 }
1517
1518
1519 pub fn has_pos_trans_type(&self) -> bool {
1521 self.message.body.has(tag::POS_TRANS_TYPE)
1522 }
1523
1524
1525
1526
1527 pub fn set_position_limit(&mut self, v: isize) {
1529 self.message.body.set_field(tag::POSITION_LIMIT, fixer::fix_int::FIXInt::from(v));
1530 }
1531
1532 pub fn get_position_limit(&self) -> Result<isize, MessageRejectErrorEnum> {
1534 let mut fld = field::PositionLimitField::new(0);
1535 self.message.body.get_field(tag::POSITION_LIMIT, &mut fld.0)?;
1536 Ok(fld.value())
1537 }
1538
1539
1540 pub fn has_position_limit(&self) -> bool {
1542 self.message.body.has(tag::POSITION_LIMIT)
1543 }
1544
1545
1546
1547
1548 pub fn set_price_quote_method(&mut self, v: String) {
1550 self.message.body.set_field(tag::PRICE_QUOTE_METHOD, FIXString::from(v));
1551 }
1552
1553 pub fn get_price_quote_method(&self) -> Result<String, MessageRejectErrorEnum> {
1555 let mut fld = field::PriceQuoteMethodField::new(String::new());
1556 self.message.body.get_field(tag::PRICE_QUOTE_METHOD, &mut fld.0)?;
1557 Ok(fld.value().to_string())
1558 }
1559
1560
1561 pub fn has_price_quote_method(&self) -> bool {
1563 self.message.body.has(tag::PRICE_QUOTE_METHOD)
1564 }
1565
1566
1567
1568
1569 pub fn set_price_unit_of_measure(&mut self, v: String) {
1571 self.message.body.set_field(tag::PRICE_UNIT_OF_MEASURE, FIXString::from(v));
1572 }
1573
1574 pub fn get_price_unit_of_measure(&self) -> Result<String, MessageRejectErrorEnum> {
1576 let mut fld = field::PriceUnitOfMeasureField::new(String::new());
1577 self.message.body.get_field(tag::PRICE_UNIT_OF_MEASURE, &mut fld.0)?;
1578 Ok(fld.value().to_string())
1579 }
1580
1581
1582 pub fn has_price_unit_of_measure(&self) -> bool {
1584 self.message.body.has(tag::PRICE_UNIT_OF_MEASURE)
1585 }
1586
1587
1588
1589
1590 pub fn set_price_unit_of_measure_qty(&mut self, val: Decimal, scale: i32) {
1592 self.message.body.set_field(tag::PRICE_UNIT_OF_MEASURE_QTY, fixer::fix_decimal::FIXDecimal { decimal: val, scale });
1593 }
1594
1595 pub fn get_price_unit_of_measure_qty(&self) -> Result<Decimal, MessageRejectErrorEnum> {
1597 let mut fld = field::PriceUnitOfMeasureQtyField::new(Decimal::ZERO, 0);
1598 self.message.body.get_field(tag::PRICE_UNIT_OF_MEASURE_QTY, &mut fld.0)?;
1599 Ok(fld.value())
1600 }
1601
1602
1603 pub fn has_price_unit_of_measure_qty(&self) -> bool {
1605 self.message.body.has(tag::PRICE_UNIT_OF_MEASURE_QTY)
1606 }
1607
1608
1609
1610
1611 pub fn set_prior_spread_indicator(&mut self, v: bool) {
1613 self.message.body.set_field(tag::PRIOR_SPREAD_INDICATOR, fixer::fix_boolean::FIXBoolean::from(v));
1614 }
1615
1616 pub fn get_prior_spread_indicator(&self) -> Result<bool, MessageRejectErrorEnum> {
1618 let mut fld = field::PriorSpreadIndicatorField::new(false);
1619 self.message.body.get_field(tag::PRIOR_SPREAD_INDICATOR, &mut fld.0)?;
1620 Ok(fld.value())
1621 }
1622
1623
1624 pub fn has_prior_spread_indicator(&self) -> bool {
1626 self.message.body.has(tag::PRIOR_SPREAD_INDICATOR)
1627 }
1628
1629
1630
1631
1632 pub fn set_product(&mut self, v: isize) {
1634 self.message.body.set_field(tag::PRODUCT, fixer::fix_int::FIXInt::from(v));
1635 }
1636
1637 pub fn get_product(&self) -> Result<isize, MessageRejectErrorEnum> {
1639 let mut fld = field::ProductField::new(0);
1640 self.message.body.get_field(tag::PRODUCT, &mut fld.0)?;
1641 Ok(fld.value())
1642 }
1643
1644
1645 pub fn has_product(&self) -> bool {
1647 self.message.body.has(tag::PRODUCT)
1648 }
1649
1650
1651
1652
1653 pub fn set_product_complex(&mut self, v: String) {
1655 self.message.body.set_field(tag::PRODUCT_COMPLEX, FIXString::from(v));
1656 }
1657
1658 pub fn get_product_complex(&self) -> Result<String, MessageRejectErrorEnum> {
1660 let mut fld = field::ProductComplexField::new(String::new());
1661 self.message.body.get_field(tag::PRODUCT_COMPLEX, &mut fld.0)?;
1662 Ok(fld.value().to_string())
1663 }
1664
1665
1666 pub fn has_product_complex(&self) -> bool {
1668 self.message.body.has(tag::PRODUCT_COMPLEX)
1669 }
1670
1671
1672
1673
1674 pub fn set_put_or_call(&mut self, v: isize) {
1676 self.message.body.set_field(tag::PUT_OR_CALL, fixer::fix_int::FIXInt::from(v));
1677 }
1678
1679 pub fn get_put_or_call(&self) -> Result<isize, MessageRejectErrorEnum> {
1681 let mut fld = field::PutOrCallField::new(0);
1682 self.message.body.get_field(tag::PUT_OR_CALL, &mut fld.0)?;
1683 Ok(fld.value())
1684 }
1685
1686
1687 pub fn has_put_or_call(&self) -> bool {
1689 self.message.body.has(tag::PUT_OR_CALL)
1690 }
1691
1692
1693
1694
1695 pub fn set_redemption_date(&mut self, v: String) {
1697 self.message.body.set_field(tag::REDEMPTION_DATE, FIXString::from(v));
1698 }
1699
1700 pub fn get_redemption_date(&self) -> Result<String, MessageRejectErrorEnum> {
1702 let mut fld = field::RedemptionDateField::new(String::new());
1703 self.message.body.get_field(tag::REDEMPTION_DATE, &mut fld.0)?;
1704 Ok(fld.value().to_string())
1705 }
1706
1707
1708 pub fn has_redemption_date(&self) -> bool {
1710 self.message.body.has(tag::REDEMPTION_DATE)
1711 }
1712
1713
1714
1715
1716 pub fn set_repo_collateral_security_type(&mut self, v: isize) {
1718 self.message.body.set_field(tag::REPO_COLLATERAL_SECURITY_TYPE, fixer::fix_int::FIXInt::from(v));
1719 }
1720
1721 pub fn get_repo_collateral_security_type(&self) -> Result<isize, MessageRejectErrorEnum> {
1723 let mut fld = field::RepoCollateralSecurityTypeField::new(0);
1724 self.message.body.get_field(tag::REPO_COLLATERAL_SECURITY_TYPE, &mut fld.0)?;
1725 Ok(fld.value())
1726 }
1727
1728
1729 pub fn has_repo_collateral_security_type(&self) -> bool {
1731 self.message.body.has(tag::REPO_COLLATERAL_SECURITY_TYPE)
1732 }
1733
1734
1735
1736
1737 pub fn set_repurchase_rate(&mut self, val: Decimal, scale: i32) {
1739 self.message.body.set_field(tag::REPURCHASE_RATE, fixer::fix_decimal::FIXDecimal { decimal: val, scale });
1740 }
1741
1742 pub fn get_repurchase_rate(&self) -> Result<Decimal, MessageRejectErrorEnum> {
1744 let mut fld = field::RepurchaseRateField::new(Decimal::ZERO, 0);
1745 self.message.body.get_field(tag::REPURCHASE_RATE, &mut fld.0)?;
1746 Ok(fld.value())
1747 }
1748
1749
1750 pub fn has_repurchase_rate(&self) -> bool {
1752 self.message.body.has(tag::REPURCHASE_RATE)
1753 }
1754
1755
1756
1757
1758 pub fn set_repurchase_term(&mut self, v: isize) {
1760 self.message.body.set_field(tag::REPURCHASE_TERM, fixer::fix_int::FIXInt::from(v));
1761 }
1762
1763 pub fn get_repurchase_term(&self) -> Result<isize, MessageRejectErrorEnum> {
1765 let mut fld = field::RepurchaseTermField::new(0);
1766 self.message.body.get_field(tag::REPURCHASE_TERM, &mut fld.0)?;
1767 Ok(fld.value())
1768 }
1769
1770
1771 pub fn has_repurchase_term(&self) -> bool {
1773 self.message.body.has(tag::REPURCHASE_TERM)
1774 }
1775
1776
1777
1778
1779 pub fn set_restructuring_type(&mut self, v: String) {
1781 self.message.body.set_field(tag::RESTRUCTURING_TYPE, FIXString::from(v));
1782 }
1783
1784 pub fn get_restructuring_type(&self) -> Result<String, MessageRejectErrorEnum> {
1786 let mut fld = field::RestructuringTypeField::new(String::new());
1787 self.message.body.get_field(tag::RESTRUCTURING_TYPE, &mut fld.0)?;
1788 Ok(fld.value().to_string())
1789 }
1790
1791
1792 pub fn has_restructuring_type(&self) -> bool {
1794 self.message.body.has(tag::RESTRUCTURING_TYPE)
1795 }
1796
1797
1798
1799
1800 pub fn set_security_desc(&mut self, v: String) {
1802 self.message.body.set_field(tag::SECURITY_DESC, FIXString::from(v));
1803 }
1804
1805 pub fn get_security_desc(&self) -> Result<String, MessageRejectErrorEnum> {
1807 let mut fld = field::SecurityDescField::new(String::new());
1808 self.message.body.get_field(tag::SECURITY_DESC, &mut fld.0)?;
1809 Ok(fld.value().to_string())
1810 }
1811
1812
1813 pub fn has_security_desc(&self) -> bool {
1815 self.message.body.has(tag::SECURITY_DESC)
1816 }
1817
1818
1819
1820
1821 pub fn set_security_exchange(&mut self, v: String) {
1823 self.message.body.set_field(tag::SECURITY_EXCHANGE, FIXString::from(v));
1824 }
1825
1826 pub fn get_security_exchange(&self) -> Result<String, MessageRejectErrorEnum> {
1828 let mut fld = field::SecurityExchangeField::new(String::new());
1829 self.message.body.get_field(tag::SECURITY_EXCHANGE, &mut fld.0)?;
1830 Ok(fld.value().to_string())
1831 }
1832
1833
1834 pub fn has_security_exchange(&self) -> bool {
1836 self.message.body.has(tag::SECURITY_EXCHANGE)
1837 }
1838
1839
1840
1841
1842 pub fn set_security_group(&mut self, v: String) {
1844 self.message.body.set_field(tag::SECURITY_GROUP, FIXString::from(v));
1845 }
1846
1847 pub fn get_security_group(&self) -> Result<String, MessageRejectErrorEnum> {
1849 let mut fld = field::SecurityGroupField::new(String::new());
1850 self.message.body.get_field(tag::SECURITY_GROUP, &mut fld.0)?;
1851 Ok(fld.value().to_string())
1852 }
1853
1854
1855 pub fn has_security_group(&self) -> bool {
1857 self.message.body.has(tag::SECURITY_GROUP)
1858 }
1859
1860
1861
1862
1863 pub fn set_security_id(&mut self, v: String) {
1865 self.message.body.set_field(tag::SECURITY_ID, FIXString::from(v));
1866 }
1867
1868 pub fn get_security_id(&self) -> Result<String, MessageRejectErrorEnum> {
1870 let mut fld = field::SecurityIDField::new(String::new());
1871 self.message.body.get_field(tag::SECURITY_ID, &mut fld.0)?;
1872 Ok(fld.value().to_string())
1873 }
1874
1875
1876 pub fn has_security_id(&self) -> bool {
1878 self.message.body.has(tag::SECURITY_ID)
1879 }
1880
1881
1882
1883
1884 pub fn set_security_id_source(&mut self, v: String) {
1886 self.message.body.set_field(tag::SECURITY_ID_SOURCE, FIXString::from(v));
1887 }
1888
1889 pub fn get_security_id_source(&self) -> Result<String, MessageRejectErrorEnum> {
1891 let mut fld = field::SecurityIDSourceField::new(String::new());
1892 self.message.body.get_field(tag::SECURITY_ID_SOURCE, &mut fld.0)?;
1893 Ok(fld.value().to_string())
1894 }
1895
1896
1897 pub fn has_security_id_source(&self) -> bool {
1899 self.message.body.has(tag::SECURITY_ID_SOURCE)
1900 }
1901
1902
1903
1904
1905 pub fn set_security_status(&mut self, v: String) {
1907 self.message.body.set_field(tag::SECURITY_STATUS, FIXString::from(v));
1908 }
1909
1910 pub fn get_security_status(&self) -> Result<String, MessageRejectErrorEnum> {
1912 let mut fld = field::SecurityStatusField::new(String::new());
1913 self.message.body.get_field(tag::SECURITY_STATUS, &mut fld.0)?;
1914 Ok(fld.value().to_string())
1915 }
1916
1917
1918 pub fn has_security_status(&self) -> bool {
1920 self.message.body.has(tag::SECURITY_STATUS)
1921 }
1922
1923
1924
1925
1926 pub fn set_security_sub_type(&mut self, v: String) {
1928 self.message.body.set_field(tag::SECURITY_SUB_TYPE, FIXString::from(v));
1929 }
1930
1931 pub fn get_security_sub_type(&self) -> Result<String, MessageRejectErrorEnum> {
1933 let mut fld = field::SecuritySubTypeField::new(String::new());
1934 self.message.body.get_field(tag::SECURITY_SUB_TYPE, &mut fld.0)?;
1935 Ok(fld.value().to_string())
1936 }
1937
1938
1939 pub fn has_security_sub_type(&self) -> bool {
1941 self.message.body.has(tag::SECURITY_SUB_TYPE)
1942 }
1943
1944
1945
1946
1947 pub fn set_security_type(&mut self, v: String) {
1949 self.message.body.set_field(tag::SECURITY_TYPE, FIXString::from(v));
1950 }
1951
1952 pub fn get_security_type(&self) -> Result<String, MessageRejectErrorEnum> {
1954 let mut fld = field::SecurityTypeField::new(String::new());
1955 self.message.body.get_field(tag::SECURITY_TYPE, &mut fld.0)?;
1956 Ok(fld.value().to_string())
1957 }
1958
1959
1960 pub fn has_security_type(&self) -> bool {
1962 self.message.body.has(tag::SECURITY_TYPE)
1963 }
1964
1965
1966
1967
1968 pub fn set_security_xml(&mut self, v: String) {
1970 self.message.body.set_field(tag::SECURITY_XML, FIXString::from(v));
1971 }
1972
1973 pub fn get_security_xml(&self) -> Result<String, MessageRejectErrorEnum> {
1975 let mut fld = field::SecurityXMLField::new(String::new());
1976 self.message.body.get_field(tag::SECURITY_XML, &mut fld.0)?;
1977 Ok(fld.value().to_string())
1978 }
1979
1980
1981 pub fn has_security_xml(&self) -> bool {
1983 self.message.body.has(tag::SECURITY_XML)
1984 }
1985
1986
1987
1988
1989 pub fn set_security_xml_len(&mut self, v: isize) {
1991 self.message.body.set_field(tag::SECURITY_XML_LEN, fixer::fix_int::FIXInt::from(v));
1992 }
1993
1994 pub fn get_security_xml_len(&self) -> Result<isize, MessageRejectErrorEnum> {
1996 let mut fld = field::SecurityXMLLenField::new(0);
1997 self.message.body.get_field(tag::SECURITY_XML_LEN, &mut fld.0)?;
1998 Ok(fld.value())
1999 }
2000
2001
2002 pub fn has_security_xml_len(&self) -> bool {
2004 self.message.body.has(tag::SECURITY_XML_LEN)
2005 }
2006
2007
2008
2009
2010 pub fn set_security_xml_schema(&mut self, v: String) {
2012 self.message.body.set_field(tag::SECURITY_XML_SCHEMA, FIXString::from(v));
2013 }
2014
2015 pub fn get_security_xml_schema(&self) -> Result<String, MessageRejectErrorEnum> {
2017 let mut fld = field::SecurityXMLSchemaField::new(String::new());
2018 self.message.body.get_field(tag::SECURITY_XML_SCHEMA, &mut fld.0)?;
2019 Ok(fld.value().to_string())
2020 }
2021
2022
2023 pub fn has_security_xml_schema(&self) -> bool {
2025 self.message.body.has(tag::SECURITY_XML_SCHEMA)
2026 }
2027
2028
2029
2030
2031 pub fn set_seniority(&mut self, v: String) {
2033 self.message.body.set_field(tag::SENIORITY, FIXString::from(v));
2034 }
2035
2036 pub fn get_seniority(&self) -> Result<String, MessageRejectErrorEnum> {
2038 let mut fld = field::SeniorityField::new(String::new());
2039 self.message.body.get_field(tag::SENIORITY, &mut fld.0)?;
2040 Ok(fld.value().to_string())
2041 }
2042
2043
2044 pub fn has_seniority(&self) -> bool {
2046 self.message.body.has(tag::SENIORITY)
2047 }
2048
2049
2050
2051
2052 pub fn set_settl_currency(&mut self, v: String) {
2054 self.message.body.set_field(tag::SETTL_CURRENCY, FIXString::from(v));
2055 }
2056
2057 pub fn get_settl_currency(&self) -> Result<String, MessageRejectErrorEnum> {
2059 let mut fld = field::SettlCurrencyField::new(String::new());
2060 self.message.body.get_field(tag::SETTL_CURRENCY, &mut fld.0)?;
2061 Ok(fld.value().to_string())
2062 }
2063
2064
2065 pub fn has_settl_currency(&self) -> bool {
2067 self.message.body.has(tag::SETTL_CURRENCY)
2068 }
2069
2070
2071
2072
2073 pub fn set_settl_method(&mut self, v: String) {
2075 self.message.body.set_field(tag::SETTL_METHOD, FIXString::from(v));
2076 }
2077
2078 pub fn get_settl_method(&self) -> Result<String, MessageRejectErrorEnum> {
2080 let mut fld = field::SettlMethodField::new(String::new());
2081 self.message.body.get_field(tag::SETTL_METHOD, &mut fld.0)?;
2082 Ok(fld.value().to_string())
2083 }
2084
2085
2086 pub fn has_settl_method(&self) -> bool {
2088 self.message.body.has(tag::SETTL_METHOD)
2089 }
2090
2091
2092
2093
2094 pub fn set_settl_sess_id(&mut self, v: String) {
2096 self.message.body.set_field(tag::SETTL_SESS_ID, FIXString::from(v));
2097 }
2098
2099 pub fn get_settl_sess_id(&self) -> Result<String, MessageRejectErrorEnum> {
2101 let mut fld = field::SettlSessIDField::new(String::new());
2102 self.message.body.get_field(tag::SETTL_SESS_ID, &mut fld.0)?;
2103 Ok(fld.value().to_string())
2104 }
2105
2106
2107 pub fn has_settl_sess_id(&self) -> bool {
2109 self.message.body.has(tag::SETTL_SESS_ID)
2110 }
2111
2112
2113
2114
2115 pub fn set_settl_sess_sub_id(&mut self, v: String) {
2117 self.message.body.set_field(tag::SETTL_SESS_SUB_ID, FIXString::from(v));
2118 }
2119
2120 pub fn get_settl_sess_sub_id(&self) -> Result<String, MessageRejectErrorEnum> {
2122 let mut fld = field::SettlSessSubIDField::new(String::new());
2123 self.message.body.get_field(tag::SETTL_SESS_SUB_ID, &mut fld.0)?;
2124 Ok(fld.value().to_string())
2125 }
2126
2127
2128 pub fn has_settl_sess_sub_id(&self) -> bool {
2130 self.message.body.has(tag::SETTL_SESS_SUB_ID)
2131 }
2132
2133
2134
2135
2136 pub fn set_settle_on_open_flag(&mut self, v: String) {
2138 self.message.body.set_field(tag::SETTLE_ON_OPEN_FLAG, FIXString::from(v));
2139 }
2140
2141 pub fn get_settle_on_open_flag(&self) -> Result<String, MessageRejectErrorEnum> {
2143 let mut fld = field::SettleOnOpenFlagField::new(String::new());
2144 self.message.body.get_field(tag::SETTLE_ON_OPEN_FLAG, &mut fld.0)?;
2145 Ok(fld.value().to_string())
2146 }
2147
2148
2149 pub fn has_settle_on_open_flag(&self) -> bool {
2151 self.message.body.has(tag::SETTLE_ON_OPEN_FLAG)
2152 }
2153
2154
2155
2156
2157 pub fn set_state_or_province_of_issue(&mut self, v: String) {
2159 self.message.body.set_field(tag::STATE_OR_PROVINCE_OF_ISSUE, FIXString::from(v));
2160 }
2161
2162 pub fn get_state_or_province_of_issue(&self) -> Result<String, MessageRejectErrorEnum> {
2164 let mut fld = field::StateOrProvinceOfIssueField::new(String::new());
2165 self.message.body.get_field(tag::STATE_OR_PROVINCE_OF_ISSUE, &mut fld.0)?;
2166 Ok(fld.value().to_string())
2167 }
2168
2169
2170 pub fn has_state_or_province_of_issue(&self) -> bool {
2172 self.message.body.has(tag::STATE_OR_PROVINCE_OF_ISSUE)
2173 }
2174
2175
2176
2177
2178 pub fn set_strike_currency(&mut self, v: String) {
2180 self.message.body.set_field(tag::STRIKE_CURRENCY, FIXString::from(v));
2181 }
2182
2183 pub fn get_strike_currency(&self) -> Result<String, MessageRejectErrorEnum> {
2185 let mut fld = field::StrikeCurrencyField::new(String::new());
2186 self.message.body.get_field(tag::STRIKE_CURRENCY, &mut fld.0)?;
2187 Ok(fld.value().to_string())
2188 }
2189
2190
2191 pub fn has_strike_currency(&self) -> bool {
2193 self.message.body.has(tag::STRIKE_CURRENCY)
2194 }
2195
2196
2197
2198
2199 pub fn set_strike_multiplier(&mut self, val: Decimal, scale: i32) {
2201 self.message.body.set_field(tag::STRIKE_MULTIPLIER, fixer::fix_decimal::FIXDecimal { decimal: val, scale });
2202 }
2203
2204 pub fn get_strike_multiplier(&self) -> Result<Decimal, MessageRejectErrorEnum> {
2206 let mut fld = field::StrikeMultiplierField::new(Decimal::ZERO, 0);
2207 self.message.body.get_field(tag::STRIKE_MULTIPLIER, &mut fld.0)?;
2208 Ok(fld.value())
2209 }
2210
2211
2212 pub fn has_strike_multiplier(&self) -> bool {
2214 self.message.body.has(tag::STRIKE_MULTIPLIER)
2215 }
2216
2217
2218
2219
2220 pub fn set_strike_price(&mut self, val: Decimal, scale: i32) {
2222 self.message.body.set_field(tag::STRIKE_PRICE, fixer::fix_decimal::FIXDecimal { decimal: val, scale });
2223 }
2224
2225 pub fn get_strike_price(&self) -> Result<Decimal, MessageRejectErrorEnum> {
2227 let mut fld = field::StrikePriceField::new(Decimal::ZERO, 0);
2228 self.message.body.get_field(tag::STRIKE_PRICE, &mut fld.0)?;
2229 Ok(fld.value())
2230 }
2231
2232
2233 pub fn has_strike_price(&self) -> bool {
2235 self.message.body.has(tag::STRIKE_PRICE)
2236 }
2237
2238
2239
2240
2241 pub fn set_strike_price_boundary_method(&mut self, v: isize) {
2243 self.message.body.set_field(tag::STRIKE_PRICE_BOUNDARY_METHOD, fixer::fix_int::FIXInt::from(v));
2244 }
2245
2246 pub fn get_strike_price_boundary_method(&self) -> Result<isize, MessageRejectErrorEnum> {
2248 let mut fld = field::StrikePriceBoundaryMethodField::new(0);
2249 self.message.body.get_field(tag::STRIKE_PRICE_BOUNDARY_METHOD, &mut fld.0)?;
2250 Ok(fld.value())
2251 }
2252
2253
2254 pub fn has_strike_price_boundary_method(&self) -> bool {
2256 self.message.body.has(tag::STRIKE_PRICE_BOUNDARY_METHOD)
2257 }
2258
2259
2260
2261
2262 pub fn set_strike_price_boundary_precision(&mut self, val: Decimal, scale: i32) {
2264 self.message.body.set_field(tag::STRIKE_PRICE_BOUNDARY_PRECISION, fixer::fix_decimal::FIXDecimal { decimal: val, scale });
2265 }
2266
2267 pub fn get_strike_price_boundary_precision(&self) -> Result<Decimal, MessageRejectErrorEnum> {
2269 let mut fld = field::StrikePriceBoundaryPrecisionField::new(Decimal::ZERO, 0);
2270 self.message.body.get_field(tag::STRIKE_PRICE_BOUNDARY_PRECISION, &mut fld.0)?;
2271 Ok(fld.value())
2272 }
2273
2274
2275 pub fn has_strike_price_boundary_precision(&self) -> bool {
2277 self.message.body.has(tag::STRIKE_PRICE_BOUNDARY_PRECISION)
2278 }
2279
2280
2281
2282
2283 pub fn set_strike_price_determination_method(&mut self, v: isize) {
2285 self.message.body.set_field(tag::STRIKE_PRICE_DETERMINATION_METHOD, fixer::fix_int::FIXInt::from(v));
2286 }
2287
2288 pub fn get_strike_price_determination_method(&self) -> Result<isize, MessageRejectErrorEnum> {
2290 let mut fld = field::StrikePriceDeterminationMethodField::new(0);
2291 self.message.body.get_field(tag::STRIKE_PRICE_DETERMINATION_METHOD, &mut fld.0)?;
2292 Ok(fld.value())
2293 }
2294
2295
2296 pub fn has_strike_price_determination_method(&self) -> bool {
2298 self.message.body.has(tag::STRIKE_PRICE_DETERMINATION_METHOD)
2299 }
2300
2301
2302
2303
2304 pub fn set_strike_value(&mut self, val: Decimal, scale: i32) {
2306 self.message.body.set_field(tag::STRIKE_VALUE, fixer::fix_decimal::FIXDecimal { decimal: val, scale });
2307 }
2308
2309 pub fn get_strike_value(&self) -> Result<Decimal, MessageRejectErrorEnum> {
2311 let mut fld = field::StrikeValueField::new(Decimal::ZERO, 0);
2312 self.message.body.get_field(tag::STRIKE_VALUE, &mut fld.0)?;
2313 Ok(fld.value())
2314 }
2315
2316
2317 pub fn has_strike_value(&self) -> bool {
2319 self.message.body.has(tag::STRIKE_VALUE)
2320 }
2321
2322
2323
2324
2325 pub fn set_symbol(&mut self, v: String) {
2327 self.message.body.set_field(tag::SYMBOL, FIXString::from(v));
2328 }
2329
2330 pub fn get_symbol(&self) -> Result<String, MessageRejectErrorEnum> {
2332 let mut fld = field::SymbolField::new(String::new());
2333 self.message.body.get_field(tag::SYMBOL, &mut fld.0)?;
2334 Ok(fld.value().to_string())
2335 }
2336
2337
2338 pub fn has_symbol(&self) -> bool {
2340 self.message.body.has(tag::SYMBOL)
2341 }
2342
2343
2344
2345
2346 pub fn set_symbol_sfx(&mut self, v: String) {
2348 self.message.body.set_field(tag::SYMBOL_SFX, FIXString::from(v));
2349 }
2350
2351 pub fn get_symbol_sfx(&self) -> Result<String, MessageRejectErrorEnum> {
2353 let mut fld = field::SymbolSfxField::new(String::new());
2354 self.message.body.get_field(tag::SYMBOL_SFX, &mut fld.0)?;
2355 Ok(fld.value().to_string())
2356 }
2357
2358
2359 pub fn has_symbol_sfx(&self) -> bool {
2361 self.message.body.has(tag::SYMBOL_SFX)
2362 }
2363
2364
2365
2366
2367 pub fn set_text(&mut self, v: String) {
2369 self.message.body.set_field(tag::TEXT, FIXString::from(v));
2370 }
2371
2372 pub fn get_text(&self) -> Result<String, MessageRejectErrorEnum> {
2374 let mut fld = field::TextField::new(String::new());
2375 self.message.body.get_field(tag::TEXT, &mut fld.0)?;
2376 Ok(fld.value().to_string())
2377 }
2378
2379
2380 pub fn has_text(&self) -> bool {
2382 self.message.body.has(tag::TEXT)
2383 }
2384
2385
2386
2387
2388 pub fn set_threshold_amount(&mut self, val: Decimal, scale: i32) {
2390 self.message.body.set_field(tag::THRESHOLD_AMOUNT, fixer::fix_decimal::FIXDecimal { decimal: val, scale });
2391 }
2392
2393 pub fn get_threshold_amount(&self) -> Result<Decimal, MessageRejectErrorEnum> {
2395 let mut fld = field::ThresholdAmountField::new(Decimal::ZERO, 0);
2396 self.message.body.get_field(tag::THRESHOLD_AMOUNT, &mut fld.0)?;
2397 Ok(fld.value())
2398 }
2399
2400
2401 pub fn has_threshold_amount(&self) -> bool {
2403 self.message.body.has(tag::THRESHOLD_AMOUNT)
2404 }
2405
2406
2407
2408
2409 pub fn set_time_unit(&mut self, v: String) {
2411 self.message.body.set_field(tag::TIME_UNIT, FIXString::from(v));
2412 }
2413
2414 pub fn get_time_unit(&self) -> Result<String, MessageRejectErrorEnum> {
2416 let mut fld = field::TimeUnitField::new(String::new());
2417 self.message.body.get_field(tag::TIME_UNIT, &mut fld.0)?;
2418 Ok(fld.value().to_string())
2419 }
2420
2421
2422 pub fn has_time_unit(&self) -> bool {
2424 self.message.body.has(tag::TIME_UNIT)
2425 }
2426
2427
2428
2429
2430 pub fn set_transact_time(&mut self, v: Timestamp) {
2432 self.message.body.set_field(tag::TRANSACT_TIME, fixer::fix_utc_timestamp::FIXUTCTimestamp {
2433 time: v,
2434 precision: fixer::fix_utc_timestamp::TimestampPrecision::Millis,
2435 });
2436 }
2437
2438 pub fn get_transact_time(&self) -> Result<Timestamp, MessageRejectErrorEnum> {
2440 let mut fld = field::TransactTimeField::new(Timestamp::UNIX_EPOCH);
2441 self.message.body.get_field(tag::TRANSACT_TIME, &mut fld.0)?;
2442 Ok(fld.value())
2443 }
2444
2445
2446 pub fn has_transact_time(&self) -> bool {
2448 self.message.body.has(tag::TRANSACT_TIME)
2449 }
2450
2451
2452
2453
2454 pub fn set_underlying_price_determination_method(&mut self, v: isize) {
2456 self.message.body.set_field(tag::UNDERLYING_PRICE_DETERMINATION_METHOD, fixer::fix_int::FIXInt::from(v));
2457 }
2458
2459 pub fn get_underlying_price_determination_method(&self) -> Result<isize, MessageRejectErrorEnum> {
2461 let mut fld = field::UnderlyingPriceDeterminationMethodField::new(0);
2462 self.message.body.get_field(tag::UNDERLYING_PRICE_DETERMINATION_METHOD, &mut fld.0)?;
2463 Ok(fld.value())
2464 }
2465
2466
2467 pub fn has_underlying_price_determination_method(&self) -> bool {
2469 self.message.body.has(tag::UNDERLYING_PRICE_DETERMINATION_METHOD)
2470 }
2471
2472
2473
2474
2475 pub fn set_unit_of_measure(&mut self, v: String) {
2477 self.message.body.set_field(tag::UNIT_OF_MEASURE, FIXString::from(v));
2478 }
2479
2480 pub fn get_unit_of_measure(&self) -> Result<String, MessageRejectErrorEnum> {
2482 let mut fld = field::UnitOfMeasureField::new(String::new());
2483 self.message.body.get_field(tag::UNIT_OF_MEASURE, &mut fld.0)?;
2484 Ok(fld.value().to_string())
2485 }
2486
2487
2488 pub fn has_unit_of_measure(&self) -> bool {
2490 self.message.body.has(tag::UNIT_OF_MEASURE)
2491 }
2492
2493
2494
2495
2496 pub fn set_unit_of_measure_qty(&mut self, val: Decimal, scale: i32) {
2498 self.message.body.set_field(tag::UNIT_OF_MEASURE_QTY, fixer::fix_decimal::FIXDecimal { decimal: val, scale });
2499 }
2500
2501 pub fn get_unit_of_measure_qty(&self) -> Result<Decimal, MessageRejectErrorEnum> {
2503 let mut fld = field::UnitOfMeasureQtyField::new(Decimal::ZERO, 0);
2504 self.message.body.get_field(tag::UNIT_OF_MEASURE_QTY, &mut fld.0)?;
2505 Ok(fld.value())
2506 }
2507
2508
2509 pub fn has_unit_of_measure_qty(&self) -> bool {
2511 self.message.body.has(tag::UNIT_OF_MEASURE_QTY)
2512 }
2513
2514
2515
2516
2517 pub fn set_valuation_method(&mut self, v: String) {
2519 self.message.body.set_field(tag::VALUATION_METHOD, FIXString::from(v));
2520 }
2521
2522 pub fn get_valuation_method(&self) -> Result<String, MessageRejectErrorEnum> {
2524 let mut fld = field::ValuationMethodField::new(String::new());
2525 self.message.body.get_field(tag::VALUATION_METHOD, &mut fld.0)?;
2526 Ok(fld.value().to_string())
2527 }
2528
2529
2530 pub fn has_valuation_method(&self) -> bool {
2532 self.message.body.has(tag::VALUATION_METHOD)
2533 }
2534
2535
2536}
2537
2538pub type RouteOut = fn(msg: PositionMaintenanceReport, session_id: SessionID) -> Result<(), MessageRejectErrorEnum>;
2540
2541pub type Route = (&'static str, &'static str, Box<dyn Fn(&Message, SessionID) -> Result<(), MessageRejectErrorEnum> + Send>);
2543
2544pub fn route(router: RouteOut) -> Route {
2546 let r = move |msg: &Message, session_id: SessionID| -> Result<(), MessageRejectErrorEnum> {
2547 router(PositionMaintenanceReport::from_message(msg.clone()), session_id)
2548 };
2549 ("9", "AM", Box::new(r))
2550}