Skip to main content

fixer_fix/fix50/
contrary_intention_report.rs

1// Code generated by fixer-gen. DO NOT EDIT.
2#![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
20/// `ContraryIntentionReport` is the `fix50` `ContraryIntentionReport` type, `MsgType` = BO.
21pub struct ContraryIntentionReport {
22    pub message: Message,
23}
24
25impl ContraryIntentionReport {
26    /// Creates a new `ContraryIntentionReport` with required fields.
27    pub fn new(cont_int_rpt_id: field::ContIntRptIDField, clearing_business_date: field::ClearingBusinessDateField) -> Self {
28        let mut msg = Message::new();
29        msg.header.set_field(tag::MSG_TYPE, FIXString::from("BO".to_string()));
30
31        msg.body.set_field(tag::CONT_INT_RPT_ID, cont_int_rpt_id.0);
32
33        msg.body.set_field(tag::CLEARING_BUSINESS_DATE, clearing_business_date.0);
34
35        Self { message: msg }
36    }
37
38    /// Creates a `ContraryIntentionReport` from an existing `Message`.
39    pub fn from_message(msg: Message) -> Self {
40        Self { message: msg }
41    }
42
43    /// Returns the underlying `Message`.
44    pub fn to_message(self) -> Message {
45        self.message
46    }
47
48
49
50
51    /// Sets `CFICode`, Tag 461.
52    pub fn set_cfi_code(&mut self, v: String) {
53        self.message.body.set_field(tag::CFI_CODE, FIXString::from(v));
54    }
55
56    /// Gets `CFICode`, Tag 461.
57    pub fn get_cfi_code(&self) -> Result<String, MessageRejectErrorEnum> {
58        let mut fld = field::CFICodeField::new(String::new());
59        self.message.body.get_field(tag::CFI_CODE, &mut fld.0)?;
60        Ok(fld.value().to_string())
61    }
62
63
64    /// Returns true if `CFICode` is present, Tag 461.
65    pub fn has_cfi_code(&self) -> bool {
66        self.message.body.has(tag::CFI_CODE)
67    }
68
69
70
71
72    /// Sets `CPProgram`, Tag 875.
73    pub fn set_cp_program(&mut self, v: isize) {
74        self.message.body.set_field(tag::CP_PROGRAM, fixer::fix_int::FIXInt::from(v));
75    }
76
77    /// Gets `CPProgram`, Tag 875.
78    pub fn get_cp_program(&self) -> Result<isize, MessageRejectErrorEnum> {
79        let mut fld = field::CPProgramField::new(0);
80        self.message.body.get_field(tag::CP_PROGRAM, &mut fld.0)?;
81        Ok(fld.value())
82    }
83
84
85    /// Returns true if `CPProgram` is present, Tag 875.
86    pub fn has_cp_program(&self) -> bool {
87        self.message.body.has(tag::CP_PROGRAM)
88    }
89
90
91
92
93    /// Sets `CPRegType`, Tag 876.
94    pub fn set_cp_reg_type(&mut self, v: String) {
95        self.message.body.set_field(tag::CP_REG_TYPE, FIXString::from(v));
96    }
97
98    /// Gets `CPRegType`, Tag 876.
99    pub fn get_cp_reg_type(&self) -> Result<String, MessageRejectErrorEnum> {
100        let mut fld = field::CPRegTypeField::new(String::new());
101        self.message.body.get_field(tag::CP_REG_TYPE, &mut fld.0)?;
102        Ok(fld.value().to_string())
103    }
104
105
106    /// Returns true if `CPRegType` is present, Tag 876.
107    pub fn has_cp_reg_type(&self) -> bool {
108        self.message.body.has(tag::CP_REG_TYPE)
109    }
110
111
112
113
114    /// Sets `ClearingBusinessDate`, Tag 715.
115    pub fn set_clearing_business_date(&mut self, v: String) {
116        self.message.body.set_field(tag::CLEARING_BUSINESS_DATE, FIXString::from(v));
117    }
118
119    /// Gets `ClearingBusinessDate`, Tag 715.
120    pub fn get_clearing_business_date(&self) -> Result<String, MessageRejectErrorEnum> {
121        let mut fld = field::ClearingBusinessDateField::new(String::new());
122        self.message.body.get_field(tag::CLEARING_BUSINESS_DATE, &mut fld.0)?;
123        Ok(fld.value().to_string())
124    }
125
126
127    /// Returns true if `ClearingBusinessDate` is present, Tag 715.
128    pub fn has_clearing_business_date(&self) -> bool {
129        self.message.body.has(tag::CLEARING_BUSINESS_DATE)
130    }
131
132
133
134
135    /// Sets `ContIntRptID`, Tag 977.
136    pub fn set_cont_int_rpt_id(&mut self, v: String) {
137        self.message.body.set_field(tag::CONT_INT_RPT_ID, FIXString::from(v));
138    }
139
140    /// Gets `ContIntRptID`, Tag 977.
141    pub fn get_cont_int_rpt_id(&self) -> Result<String, MessageRejectErrorEnum> {
142        let mut fld = field::ContIntRptIDField::new(String::new());
143        self.message.body.get_field(tag::CONT_INT_RPT_ID, &mut fld.0)?;
144        Ok(fld.value().to_string())
145    }
146
147
148    /// Returns true if `ContIntRptID` is present, Tag 977.
149    pub fn has_cont_int_rpt_id(&self) -> bool {
150        self.message.body.has(tag::CONT_INT_RPT_ID)
151    }
152
153
154
155
156    /// Sets `ContractMultiplier`, Tag 231.
157    pub fn set_contract_multiplier(&mut self, val: Decimal, scale: i32) {
158        self.message.body.set_field(tag::CONTRACT_MULTIPLIER, fixer::fix_decimal::FIXDecimal { decimal: val, scale });
159    }
160
161    /// Gets `ContractMultiplier`, Tag 231.
162    pub fn get_contract_multiplier(&self) -> Result<Decimal, MessageRejectErrorEnum> {
163        let mut fld = field::ContractMultiplierField::new(Decimal::ZERO, 0);
164        self.message.body.get_field(tag::CONTRACT_MULTIPLIER, &mut fld.0)?;
165        Ok(fld.value())
166    }
167
168
169    /// Returns true if `ContractMultiplier` is present, Tag 231.
170    pub fn has_contract_multiplier(&self) -> bool {
171        self.message.body.has(tag::CONTRACT_MULTIPLIER)
172    }
173
174
175
176
177    /// Sets `ContractSettlMonth`, Tag 667.
178    pub fn set_contract_settl_month(&mut self, v: String) {
179        self.message.body.set_field(tag::CONTRACT_SETTL_MONTH, FIXString::from(v));
180    }
181
182    /// Gets `ContractSettlMonth`, Tag 667.
183    pub fn get_contract_settl_month(&self) -> Result<String, MessageRejectErrorEnum> {
184        let mut fld = field::ContractSettlMonthField::new(String::new());
185        self.message.body.get_field(tag::CONTRACT_SETTL_MONTH, &mut fld.0)?;
186        Ok(fld.value().to_string())
187    }
188
189
190    /// Returns true if `ContractSettlMonth` is present, Tag 667.
191    pub fn has_contract_settl_month(&self) -> bool {
192        self.message.body.has(tag::CONTRACT_SETTL_MONTH)
193    }
194
195
196
197
198    /// Sets `CountryOfIssue`, Tag 470.
199    pub fn set_country_of_issue(&mut self, v: String) {
200        self.message.body.set_field(tag::COUNTRY_OF_ISSUE, FIXString::from(v));
201    }
202
203    /// Gets `CountryOfIssue`, Tag 470.
204    pub fn get_country_of_issue(&self) -> Result<String, MessageRejectErrorEnum> {
205        let mut fld = field::CountryOfIssueField::new(String::new());
206        self.message.body.get_field(tag::COUNTRY_OF_ISSUE, &mut fld.0)?;
207        Ok(fld.value().to_string())
208    }
209
210
211    /// Returns true if `CountryOfIssue` is present, Tag 470.
212    pub fn has_country_of_issue(&self) -> bool {
213        self.message.body.has(tag::COUNTRY_OF_ISSUE)
214    }
215
216
217
218
219    /// Sets `CouponPaymentDate`, Tag 224.
220    pub fn set_coupon_payment_date(&mut self, v: String) {
221        self.message.body.set_field(tag::COUPON_PAYMENT_DATE, FIXString::from(v));
222    }
223
224    /// Gets `CouponPaymentDate`, Tag 224.
225    pub fn get_coupon_payment_date(&self) -> Result<String, MessageRejectErrorEnum> {
226        let mut fld = field::CouponPaymentDateField::new(String::new());
227        self.message.body.get_field(tag::COUPON_PAYMENT_DATE, &mut fld.0)?;
228        Ok(fld.value().to_string())
229    }
230
231
232    /// Returns true if `CouponPaymentDate` is present, Tag 224.
233    pub fn has_coupon_payment_date(&self) -> bool {
234        self.message.body.has(tag::COUPON_PAYMENT_DATE)
235    }
236
237
238
239
240    /// Sets `CouponRate`, Tag 223.
241    pub fn set_coupon_rate(&mut self, val: Decimal, scale: i32) {
242        self.message.body.set_field(tag::COUPON_RATE, fixer::fix_decimal::FIXDecimal { decimal: val, scale });
243    }
244
245    /// Gets `CouponRate`, Tag 223.
246    pub fn get_coupon_rate(&self) -> Result<Decimal, MessageRejectErrorEnum> {
247        let mut fld = field::CouponRateField::new(Decimal::ZERO, 0);
248        self.message.body.get_field(tag::COUPON_RATE, &mut fld.0)?;
249        Ok(fld.value())
250    }
251
252
253    /// Returns true if `CouponRate` is present, Tag 223.
254    pub fn has_coupon_rate(&self) -> bool {
255        self.message.body.has(tag::COUPON_RATE)
256    }
257
258
259
260
261    /// Sets `CreditRating`, Tag 255.
262    pub fn set_credit_rating(&mut self, v: String) {
263        self.message.body.set_field(tag::CREDIT_RATING, FIXString::from(v));
264    }
265
266    /// Gets `CreditRating`, Tag 255.
267    pub fn get_credit_rating(&self) -> Result<String, MessageRejectErrorEnum> {
268        let mut fld = field::CreditRatingField::new(String::new());
269        self.message.body.get_field(tag::CREDIT_RATING, &mut fld.0)?;
270        Ok(fld.value().to_string())
271    }
272
273
274    /// Returns true if `CreditRating` is present, Tag 255.
275    pub fn has_credit_rating(&self) -> bool {
276        self.message.body.has(tag::CREDIT_RATING)
277    }
278
279
280
281
282    /// Sets `DatedDate`, Tag 873.
283    pub fn set_dated_date(&mut self, v: String) {
284        self.message.body.set_field(tag::DATED_DATE, FIXString::from(v));
285    }
286
287    /// Gets `DatedDate`, Tag 873.
288    pub fn get_dated_date(&self) -> Result<String, MessageRejectErrorEnum> {
289        let mut fld = field::DatedDateField::new(String::new());
290        self.message.body.get_field(tag::DATED_DATE, &mut fld.0)?;
291        Ok(fld.value().to_string())
292    }
293
294
295    /// Returns true if `DatedDate` is present, Tag 873.
296    pub fn has_dated_date(&self) -> bool {
297        self.message.body.has(tag::DATED_DATE)
298    }
299
300
301
302
303    /// Sets `EncodedIssuer`, Tag 349.
304    pub fn set_encoded_issuer(&mut self, v: String) {
305        self.message.body.set_field(tag::ENCODED_ISSUER, FIXString::from(v));
306    }
307
308    /// Gets `EncodedIssuer`, Tag 349.
309    pub fn get_encoded_issuer(&self) -> Result<String, MessageRejectErrorEnum> {
310        let mut fld = field::EncodedIssuerField::new(String::new());
311        self.message.body.get_field(tag::ENCODED_ISSUER, &mut fld.0)?;
312        Ok(fld.value().to_string())
313    }
314
315
316    /// Returns true if `EncodedIssuer` is present, Tag 349.
317    pub fn has_encoded_issuer(&self) -> bool {
318        self.message.body.has(tag::ENCODED_ISSUER)
319    }
320
321
322
323
324    /// Sets `EncodedIssuerLen`, Tag 348.
325    pub fn set_encoded_issuer_len(&mut self, v: isize) {
326        self.message.body.set_field(tag::ENCODED_ISSUER_LEN, fixer::fix_int::FIXInt::from(v));
327    }
328
329    /// Gets `EncodedIssuerLen`, Tag 348.
330    pub fn get_encoded_issuer_len(&self) -> Result<isize, MessageRejectErrorEnum> {
331        let mut fld = field::EncodedIssuerLenField::new(0);
332        self.message.body.get_field(tag::ENCODED_ISSUER_LEN, &mut fld.0)?;
333        Ok(fld.value())
334    }
335
336
337    /// Returns true if `EncodedIssuerLen` is present, Tag 348.
338    pub fn has_encoded_issuer_len(&self) -> bool {
339        self.message.body.has(tag::ENCODED_ISSUER_LEN)
340    }
341
342
343
344
345    /// Sets `EncodedSecurityDesc`, Tag 351.
346    pub fn set_encoded_security_desc(&mut self, v: String) {
347        self.message.body.set_field(tag::ENCODED_SECURITY_DESC, FIXString::from(v));
348    }
349
350    /// Gets `EncodedSecurityDesc`, Tag 351.
351    pub fn get_encoded_security_desc(&self) -> Result<String, MessageRejectErrorEnum> {
352        let mut fld = field::EncodedSecurityDescField::new(String::new());
353        self.message.body.get_field(tag::ENCODED_SECURITY_DESC, &mut fld.0)?;
354        Ok(fld.value().to_string())
355    }
356
357
358    /// Returns true if `EncodedSecurityDesc` is present, Tag 351.
359    pub fn has_encoded_security_desc(&self) -> bool {
360        self.message.body.has(tag::ENCODED_SECURITY_DESC)
361    }
362
363
364
365
366    /// Sets `EncodedSecurityDescLen`, Tag 350.
367    pub fn set_encoded_security_desc_len(&mut self, v: isize) {
368        self.message.body.set_field(tag::ENCODED_SECURITY_DESC_LEN, fixer::fix_int::FIXInt::from(v));
369    }
370
371    /// Gets `EncodedSecurityDescLen`, Tag 350.
372    pub fn get_encoded_security_desc_len(&self) -> Result<isize, MessageRejectErrorEnum> {
373        let mut fld = field::EncodedSecurityDescLenField::new(0);
374        self.message.body.get_field(tag::ENCODED_SECURITY_DESC_LEN, &mut fld.0)?;
375        Ok(fld.value())
376    }
377
378
379    /// Returns true if `EncodedSecurityDescLen` is present, Tag 350.
380    pub fn has_encoded_security_desc_len(&self) -> bool {
381        self.message.body.has(tag::ENCODED_SECURITY_DESC_LEN)
382    }
383
384
385
386
387    /// Sets `EncodedText`, Tag 355.
388    pub fn set_encoded_text(&mut self, v: String) {
389        self.message.body.set_field(tag::ENCODED_TEXT, FIXString::from(v));
390    }
391
392    /// Gets `EncodedText`, Tag 355.
393    pub fn get_encoded_text(&self) -> Result<String, MessageRejectErrorEnum> {
394        let mut fld = field::EncodedTextField::new(String::new());
395        self.message.body.get_field(tag::ENCODED_TEXT, &mut fld.0)?;
396        Ok(fld.value().to_string())
397    }
398
399
400    /// Returns true if `EncodedText` is present, Tag 355.
401    pub fn has_encoded_text(&self) -> bool {
402        self.message.body.has(tag::ENCODED_TEXT)
403    }
404
405
406
407
408    /// Sets `EncodedTextLen`, Tag 354.
409    pub fn set_encoded_text_len(&mut self, v: isize) {
410        self.message.body.set_field(tag::ENCODED_TEXT_LEN, fixer::fix_int::FIXInt::from(v));
411    }
412
413    /// Gets `EncodedTextLen`, Tag 354.
414    pub fn get_encoded_text_len(&self) -> Result<isize, MessageRejectErrorEnum> {
415        let mut fld = field::EncodedTextLenField::new(0);
416        self.message.body.get_field(tag::ENCODED_TEXT_LEN, &mut fld.0)?;
417        Ok(fld.value())
418    }
419
420
421    /// Returns true if `EncodedTextLen` is present, Tag 354.
422    pub fn has_encoded_text_len(&self) -> bool {
423        self.message.body.has(tag::ENCODED_TEXT_LEN)
424    }
425
426
427
428
429    /// Sets `Factor`, Tag 228.
430    pub fn set_factor(&mut self, val: Decimal, scale: i32) {
431        self.message.body.set_field(tag::FACTOR, fixer::fix_decimal::FIXDecimal { decimal: val, scale });
432    }
433
434    /// Gets `Factor`, Tag 228.
435    pub fn get_factor(&self) -> Result<Decimal, MessageRejectErrorEnum> {
436        let mut fld = field::FactorField::new(Decimal::ZERO, 0);
437        self.message.body.get_field(tag::FACTOR, &mut fld.0)?;
438        Ok(fld.value())
439    }
440
441
442    /// Returns true if `Factor` is present, Tag 228.
443    pub fn has_factor(&self) -> bool {
444        self.message.body.has(tag::FACTOR)
445    }
446
447
448
449
450    /// Sets `InputSource`, Tag 979.
451    pub fn set_input_source(&mut self, v: String) {
452        self.message.body.set_field(tag::INPUT_SOURCE, FIXString::from(v));
453    }
454
455    /// Gets `InputSource`, Tag 979.
456    pub fn get_input_source(&self) -> Result<String, MessageRejectErrorEnum> {
457        let mut fld = field::InputSourceField::new(String::new());
458        self.message.body.get_field(tag::INPUT_SOURCE, &mut fld.0)?;
459        Ok(fld.value().to_string())
460    }
461
462
463    /// Returns true if `InputSource` is present, Tag 979.
464    pub fn has_input_source(&self) -> bool {
465        self.message.body.has(tag::INPUT_SOURCE)
466    }
467
468
469
470
471    /// Sets `InstrRegistry`, Tag 543.
472    pub fn set_instr_registry(&mut self, v: String) {
473        self.message.body.set_field(tag::INSTR_REGISTRY, FIXString::from(v));
474    }
475
476    /// Gets `InstrRegistry`, Tag 543.
477    pub fn get_instr_registry(&self) -> Result<String, MessageRejectErrorEnum> {
478        let mut fld = field::InstrRegistryField::new(String::new());
479        self.message.body.get_field(tag::INSTR_REGISTRY, &mut fld.0)?;
480        Ok(fld.value().to_string())
481    }
482
483
484    /// Returns true if `InstrRegistry` is present, Tag 543.
485    pub fn has_instr_registry(&self) -> bool {
486        self.message.body.has(tag::INSTR_REGISTRY)
487    }
488
489
490
491
492    /// Sets `InstrmtAssignmentMethod`, Tag 1049.
493    pub fn set_instrmt_assignment_method(&mut self, v: String) {
494        self.message.body.set_field(tag::INSTRMT_ASSIGNMENT_METHOD, FIXString::from(v));
495    }
496
497    /// Gets `InstrmtAssignmentMethod`, Tag 1049.
498    pub fn get_instrmt_assignment_method(&self) -> Result<String, MessageRejectErrorEnum> {
499        let mut fld = field::InstrmtAssignmentMethodField::new(String::new());
500        self.message.body.get_field(tag::INSTRMT_ASSIGNMENT_METHOD, &mut fld.0)?;
501        Ok(fld.value().to_string())
502    }
503
504
505    /// Returns true if `InstrmtAssignmentMethod` is present, Tag 1049.
506    pub fn has_instrmt_assignment_method(&self) -> bool {
507        self.message.body.has(tag::INSTRMT_ASSIGNMENT_METHOD)
508    }
509
510
511
512
513    /// Sets `InterestAccrualDate`, Tag 874.
514    pub fn set_interest_accrual_date(&mut self, v: String) {
515        self.message.body.set_field(tag::INTEREST_ACCRUAL_DATE, FIXString::from(v));
516    }
517
518    /// Gets `InterestAccrualDate`, Tag 874.
519    pub fn get_interest_accrual_date(&self) -> Result<String, MessageRejectErrorEnum> {
520        let mut fld = field::InterestAccrualDateField::new(String::new());
521        self.message.body.get_field(tag::INTEREST_ACCRUAL_DATE, &mut fld.0)?;
522        Ok(fld.value().to_string())
523    }
524
525
526    /// Returns true if `InterestAccrualDate` is present, Tag 874.
527    pub fn has_interest_accrual_date(&self) -> bool {
528        self.message.body.has(tag::INTEREST_ACCRUAL_DATE)
529    }
530
531
532
533
534    /// Sets `IssueDate`, Tag 225.
535    pub fn set_issue_date(&mut self, v: String) {
536        self.message.body.set_field(tag::ISSUE_DATE, FIXString::from(v));
537    }
538
539    /// Gets `IssueDate`, Tag 225.
540    pub fn get_issue_date(&self) -> Result<String, MessageRejectErrorEnum> {
541        let mut fld = field::IssueDateField::new(String::new());
542        self.message.body.get_field(tag::ISSUE_DATE, &mut fld.0)?;
543        Ok(fld.value().to_string())
544    }
545
546
547    /// Returns true if `IssueDate` is present, Tag 225.
548    pub fn has_issue_date(&self) -> bool {
549        self.message.body.has(tag::ISSUE_DATE)
550    }
551
552
553
554
555    /// Sets `Issuer`, Tag 106.
556    pub fn set_issuer(&mut self, v: String) {
557        self.message.body.set_field(tag::ISSUER, FIXString::from(v));
558    }
559
560    /// Gets `Issuer`, Tag 106.
561    pub fn get_issuer(&self) -> Result<String, MessageRejectErrorEnum> {
562        let mut fld = field::IssuerField::new(String::new());
563        self.message.body.get_field(tag::ISSUER, &mut fld.0)?;
564        Ok(fld.value().to_string())
565    }
566
567
568    /// Returns true if `Issuer` is present, Tag 106.
569    pub fn has_issuer(&self) -> bool {
570        self.message.body.has(tag::ISSUER)
571    }
572
573
574
575
576    /// Sets `LateIndicator`, Tag 978.
577    pub fn set_late_indicator(&mut self, v: bool) {
578        self.message.body.set_field(tag::LATE_INDICATOR, fixer::fix_boolean::FIXBoolean::from(v));
579    }
580
581    /// Gets `LateIndicator`, Tag 978.
582    pub fn get_late_indicator(&self) -> Result<bool, MessageRejectErrorEnum> {
583        let mut fld = field::LateIndicatorField::new(false);
584        self.message.body.get_field(tag::LATE_INDICATOR, &mut fld.0)?;
585        Ok(fld.value())
586    }
587
588
589    /// Returns true if `LateIndicator` is present, Tag 978.
590    pub fn has_late_indicator(&self) -> bool {
591        self.message.body.has(tag::LATE_INDICATOR)
592    }
593
594
595
596
597    /// Sets `LocaleOfIssue`, Tag 472.
598    pub fn set_locale_of_issue(&mut self, v: String) {
599        self.message.body.set_field(tag::LOCALE_OF_ISSUE, FIXString::from(v));
600    }
601
602    /// Gets `LocaleOfIssue`, Tag 472.
603    pub fn get_locale_of_issue(&self) -> Result<String, MessageRejectErrorEnum> {
604        let mut fld = field::LocaleOfIssueField::new(String::new());
605        self.message.body.get_field(tag::LOCALE_OF_ISSUE, &mut fld.0)?;
606        Ok(fld.value().to_string())
607    }
608
609
610    /// Returns true if `LocaleOfIssue` is present, Tag 472.
611    pub fn has_locale_of_issue(&self) -> bool {
612        self.message.body.has(tag::LOCALE_OF_ISSUE)
613    }
614
615
616
617
618    /// Sets `MaturityDate`, Tag 541.
619    pub fn set_maturity_date(&mut self, v: String) {
620        self.message.body.set_field(tag::MATURITY_DATE, FIXString::from(v));
621    }
622
623    /// Gets `MaturityDate`, Tag 541.
624    pub fn get_maturity_date(&self) -> Result<String, MessageRejectErrorEnum> {
625        let mut fld = field::MaturityDateField::new(String::new());
626        self.message.body.get_field(tag::MATURITY_DATE, &mut fld.0)?;
627        Ok(fld.value().to_string())
628    }
629
630
631    /// Returns true if `MaturityDate` is present, Tag 541.
632    pub fn has_maturity_date(&self) -> bool {
633        self.message.body.has(tag::MATURITY_DATE)
634    }
635
636
637
638
639    /// Sets `MaturityMonthYear`, Tag 200.
640    pub fn set_maturity_month_year(&mut self, v: String) {
641        self.message.body.set_field(tag::MATURITY_MONTH_YEAR, FIXString::from(v));
642    }
643
644    /// Gets `MaturityMonthYear`, Tag 200.
645    pub fn get_maturity_month_year(&self) -> Result<String, MessageRejectErrorEnum> {
646        let mut fld = field::MaturityMonthYearField::new(String::new());
647        self.message.body.get_field(tag::MATURITY_MONTH_YEAR, &mut fld.0)?;
648        Ok(fld.value().to_string())
649    }
650
651
652    /// Returns true if `MaturityMonthYear` is present, Tag 200.
653    pub fn has_maturity_month_year(&self) -> bool {
654        self.message.body.has(tag::MATURITY_MONTH_YEAR)
655    }
656
657
658
659
660    /// Sets `MaturityTime`, Tag 1079.
661    pub fn set_maturity_time(&mut self, v: String) {
662        self.message.body.set_field(tag::MATURITY_TIME, FIXString::from(v));
663    }
664
665    /// Gets `MaturityTime`, Tag 1079.
666    pub fn get_maturity_time(&self) -> Result<String, MessageRejectErrorEnum> {
667        let mut fld = field::MaturityTimeField::new(String::new());
668        self.message.body.get_field(tag::MATURITY_TIME, &mut fld.0)?;
669        Ok(fld.value().to_string())
670    }
671
672
673    /// Returns true if `MaturityTime` is present, Tag 1079.
674    pub fn has_maturity_time(&self) -> bool {
675        self.message.body.has(tag::MATURITY_TIME)
676    }
677
678
679
680
681    /// Sets `MinPriceIncrement`, Tag 969.
682    pub fn set_min_price_increment(&mut self, val: Decimal, scale: i32) {
683        self.message.body.set_field(tag::MIN_PRICE_INCREMENT, fixer::fix_decimal::FIXDecimal { decimal: val, scale });
684    }
685
686    /// Gets `MinPriceIncrement`, Tag 969.
687    pub fn get_min_price_increment(&self) -> Result<Decimal, MessageRejectErrorEnum> {
688        let mut fld = field::MinPriceIncrementField::new(Decimal::ZERO, 0);
689        self.message.body.get_field(tag::MIN_PRICE_INCREMENT, &mut fld.0)?;
690        Ok(fld.value())
691    }
692
693
694    /// Returns true if `MinPriceIncrement` is present, Tag 969.
695    pub fn has_min_price_increment(&self) -> bool {
696        self.message.body.has(tag::MIN_PRICE_INCREMENT)
697    }
698
699
700
701
702    /// Sets `NTPositionLimit`, Tag 971.
703    pub fn set_nt_position_limit(&mut self, v: isize) {
704        self.message.body.set_field(tag::NT_POSITION_LIMIT, fixer::fix_int::FIXInt::from(v));
705    }
706
707    /// Gets `NTPositionLimit`, Tag 971.
708    pub fn get_nt_position_limit(&self) -> Result<isize, MessageRejectErrorEnum> {
709        let mut fld = field::NTPositionLimitField::new(0);
710        self.message.body.get_field(tag::NT_POSITION_LIMIT, &mut fld.0)?;
711        Ok(fld.value())
712    }
713
714
715    /// Returns true if `NTPositionLimit` is present, Tag 971.
716    pub fn has_nt_position_limit(&self) -> bool {
717        self.message.body.has(tag::NT_POSITION_LIMIT)
718    }
719
720
721
722
723    /// Sets `NoEvents`, Tag 864.
724    pub fn set_no_events(&mut self, v: isize) {
725        self.message.body.set_field(tag::NO_EVENTS, fixer::fix_int::FIXInt::from(v));
726    }
727
728    /// Gets `NoEvents`, Tag 864.
729    pub fn get_no_events(&self) -> Result<isize, MessageRejectErrorEnum> {
730        let mut fld = field::NoEventsField::new(0);
731        self.message.body.get_field(tag::NO_EVENTS, &mut fld.0)?;
732        Ok(fld.value())
733    }
734
735
736    /// Returns true if `NoEvents` is present, Tag 864.
737    pub fn has_no_events(&self) -> bool {
738        self.message.body.has(tag::NO_EVENTS)
739    }
740
741
742
743
744    /// Sets `NoExpiration`, Tag 981.
745    pub fn set_no_expiration(&mut self, v: isize) {
746        self.message.body.set_field(tag::NO_EXPIRATION, fixer::fix_int::FIXInt::from(v));
747    }
748
749    /// Gets `NoExpiration`, Tag 981.
750    pub fn get_no_expiration(&self) -> Result<isize, MessageRejectErrorEnum> {
751        let mut fld = field::NoExpirationField::new(0);
752        self.message.body.get_field(tag::NO_EXPIRATION, &mut fld.0)?;
753        Ok(fld.value())
754    }
755
756
757    /// Returns true if `NoExpiration` is present, Tag 981.
758    pub fn has_no_expiration(&self) -> bool {
759        self.message.body.has(tag::NO_EXPIRATION)
760    }
761
762
763
764
765    /// Sets `NoInstrumentParties`, Tag 1018.
766    pub fn set_no_instrument_parties(&mut self, v: isize) {
767        self.message.body.set_field(tag::NO_INSTRUMENT_PARTIES, fixer::fix_int::FIXInt::from(v));
768    }
769
770    /// Gets `NoInstrumentParties`, Tag 1018.
771    pub fn get_no_instrument_parties(&self) -> Result<isize, MessageRejectErrorEnum> {
772        let mut fld = field::NoInstrumentPartiesField::new(0);
773        self.message.body.get_field(tag::NO_INSTRUMENT_PARTIES, &mut fld.0)?;
774        Ok(fld.value())
775    }
776
777
778    /// Returns true if `NoInstrumentParties` is present, Tag 1018.
779    pub fn has_no_instrument_parties(&self) -> bool {
780        self.message.body.has(tag::NO_INSTRUMENT_PARTIES)
781    }
782
783
784
785
786    /// Sets `NoPartyIDs`, Tag 453.
787    pub fn set_no_party_i_ds(&mut self, v: isize) {
788        self.message.body.set_field(tag::NO_PARTY_I_DS, fixer::fix_int::FIXInt::from(v));
789    }
790
791    /// Gets `NoPartyIDs`, Tag 453.
792    pub fn get_no_party_i_ds(&self) -> Result<isize, MessageRejectErrorEnum> {
793        let mut fld = field::NoPartyIDsField::new(0);
794        self.message.body.get_field(tag::NO_PARTY_I_DS, &mut fld.0)?;
795        Ok(fld.value())
796    }
797
798
799    /// Returns true if `NoPartyIDs` is present, Tag 453.
800    pub fn has_no_party_i_ds(&self) -> bool {
801        self.message.body.has(tag::NO_PARTY_I_DS)
802    }
803
804
805
806
807    /// Sets `NoSecurityAltID`, Tag 454.
808    pub fn set_no_security_alt_id(&mut self, v: isize) {
809        self.message.body.set_field(tag::NO_SECURITY_ALT_ID, fixer::fix_int::FIXInt::from(v));
810    }
811
812    /// Gets `NoSecurityAltID`, Tag 454.
813    pub fn get_no_security_alt_id(&self) -> Result<isize, MessageRejectErrorEnum> {
814        let mut fld = field::NoSecurityAltIDField::new(0);
815        self.message.body.get_field(tag::NO_SECURITY_ALT_ID, &mut fld.0)?;
816        Ok(fld.value())
817    }
818
819
820    /// Returns true if `NoSecurityAltID` is present, Tag 454.
821    pub fn has_no_security_alt_id(&self) -> bool {
822        self.message.body.has(tag::NO_SECURITY_ALT_ID)
823    }
824
825
826
827
828    /// Sets `NoUnderlyings`, Tag 711.
829    pub fn set_no_underlyings(&mut self, v: isize) {
830        self.message.body.set_field(tag::NO_UNDERLYINGS, fixer::fix_int::FIXInt::from(v));
831    }
832
833    /// Gets `NoUnderlyings`, Tag 711.
834    pub fn get_no_underlyings(&self) -> Result<isize, MessageRejectErrorEnum> {
835        let mut fld = field::NoUnderlyingsField::new(0);
836        self.message.body.get_field(tag::NO_UNDERLYINGS, &mut fld.0)?;
837        Ok(fld.value())
838    }
839
840
841    /// Returns true if `NoUnderlyings` is present, Tag 711.
842    pub fn has_no_underlyings(&self) -> bool {
843        self.message.body.has(tag::NO_UNDERLYINGS)
844    }
845
846
847
848
849    /// Sets `OptAttribute`, Tag 206.
850    pub fn set_opt_attribute(&mut self, v: String) {
851        self.message.body.set_field(tag::OPT_ATTRIBUTE, FIXString::from(v));
852    }
853
854    /// Gets `OptAttribute`, Tag 206.
855    pub fn get_opt_attribute(&self) -> Result<String, MessageRejectErrorEnum> {
856        let mut fld = field::OptAttributeField::new(String::new());
857        self.message.body.get_field(tag::OPT_ATTRIBUTE, &mut fld.0)?;
858        Ok(fld.value().to_string())
859    }
860
861
862    /// Returns true if `OptAttribute` is present, Tag 206.
863    pub fn has_opt_attribute(&self) -> bool {
864        self.message.body.has(tag::OPT_ATTRIBUTE)
865    }
866
867
868
869
870    /// Sets `Pool`, Tag 691.
871    pub fn set_pool(&mut self, v: String) {
872        self.message.body.set_field(tag::POOL, FIXString::from(v));
873    }
874
875    /// Gets `Pool`, Tag 691.
876    pub fn get_pool(&self) -> Result<String, MessageRejectErrorEnum> {
877        let mut fld = field::PoolField::new(String::new());
878        self.message.body.get_field(tag::POOL, &mut fld.0)?;
879        Ok(fld.value().to_string())
880    }
881
882
883    /// Returns true if `Pool` is present, Tag 691.
884    pub fn has_pool(&self) -> bool {
885        self.message.body.has(tag::POOL)
886    }
887
888
889
890
891    /// Sets `PositionLimit`, Tag 970.
892    pub fn set_position_limit(&mut self, v: isize) {
893        self.message.body.set_field(tag::POSITION_LIMIT, fixer::fix_int::FIXInt::from(v));
894    }
895
896    /// Gets `PositionLimit`, Tag 970.
897    pub fn get_position_limit(&self) -> Result<isize, MessageRejectErrorEnum> {
898        let mut fld = field::PositionLimitField::new(0);
899        self.message.body.get_field(tag::POSITION_LIMIT, &mut fld.0)?;
900        Ok(fld.value())
901    }
902
903
904    /// Returns true if `PositionLimit` is present, Tag 970.
905    pub fn has_position_limit(&self) -> bool {
906        self.message.body.has(tag::POSITION_LIMIT)
907    }
908
909
910
911
912    /// Sets `Product`, Tag 460.
913    pub fn set_product(&mut self, v: isize) {
914        self.message.body.set_field(tag::PRODUCT, fixer::fix_int::FIXInt::from(v));
915    }
916
917    /// Gets `Product`, Tag 460.
918    pub fn get_product(&self) -> Result<isize, MessageRejectErrorEnum> {
919        let mut fld = field::ProductField::new(0);
920        self.message.body.get_field(tag::PRODUCT, &mut fld.0)?;
921        Ok(fld.value())
922    }
923
924
925    /// Returns true if `Product` is present, Tag 460.
926    pub fn has_product(&self) -> bool {
927        self.message.body.has(tag::PRODUCT)
928    }
929
930
931
932
933    /// Sets `RedemptionDate`, Tag 240.
934    pub fn set_redemption_date(&mut self, v: String) {
935        self.message.body.set_field(tag::REDEMPTION_DATE, FIXString::from(v));
936    }
937
938    /// Gets `RedemptionDate`, Tag 240.
939    pub fn get_redemption_date(&self) -> Result<String, MessageRejectErrorEnum> {
940        let mut fld = field::RedemptionDateField::new(String::new());
941        self.message.body.get_field(tag::REDEMPTION_DATE, &mut fld.0)?;
942        Ok(fld.value().to_string())
943    }
944
945
946    /// Returns true if `RedemptionDate` is present, Tag 240.
947    pub fn has_redemption_date(&self) -> bool {
948        self.message.body.has(tag::REDEMPTION_DATE)
949    }
950
951
952
953
954    /// Sets `RepoCollateralSecurityType`, Tag 239.
955    pub fn set_repo_collateral_security_type(&mut self, v: isize) {
956        self.message.body.set_field(tag::REPO_COLLATERAL_SECURITY_TYPE, fixer::fix_int::FIXInt::from(v));
957    }
958
959    /// Gets `RepoCollateralSecurityType`, Tag 239.
960    pub fn get_repo_collateral_security_type(&self) -> Result<isize, MessageRejectErrorEnum> {
961        let mut fld = field::RepoCollateralSecurityTypeField::new(0);
962        self.message.body.get_field(tag::REPO_COLLATERAL_SECURITY_TYPE, &mut fld.0)?;
963        Ok(fld.value())
964    }
965
966
967    /// Returns true if `RepoCollateralSecurityType` is present, Tag 239.
968    pub fn has_repo_collateral_security_type(&self) -> bool {
969        self.message.body.has(tag::REPO_COLLATERAL_SECURITY_TYPE)
970    }
971
972
973
974
975    /// Sets `RepurchaseRate`, Tag 227.
976    pub fn set_repurchase_rate(&mut self, val: Decimal, scale: i32) {
977        self.message.body.set_field(tag::REPURCHASE_RATE, fixer::fix_decimal::FIXDecimal { decimal: val, scale });
978    }
979
980    /// Gets `RepurchaseRate`, Tag 227.
981    pub fn get_repurchase_rate(&self) -> Result<Decimal, MessageRejectErrorEnum> {
982        let mut fld = field::RepurchaseRateField::new(Decimal::ZERO, 0);
983        self.message.body.get_field(tag::REPURCHASE_RATE, &mut fld.0)?;
984        Ok(fld.value())
985    }
986
987
988    /// Returns true if `RepurchaseRate` is present, Tag 227.
989    pub fn has_repurchase_rate(&self) -> bool {
990        self.message.body.has(tag::REPURCHASE_RATE)
991    }
992
993
994
995
996    /// Sets `RepurchaseTerm`, Tag 226.
997    pub fn set_repurchase_term(&mut self, v: isize) {
998        self.message.body.set_field(tag::REPURCHASE_TERM, fixer::fix_int::FIXInt::from(v));
999    }
1000
1001    /// Gets `RepurchaseTerm`, Tag 226.
1002    pub fn get_repurchase_term(&self) -> Result<isize, MessageRejectErrorEnum> {
1003        let mut fld = field::RepurchaseTermField::new(0);
1004        self.message.body.get_field(tag::REPURCHASE_TERM, &mut fld.0)?;
1005        Ok(fld.value())
1006    }
1007
1008
1009    /// Returns true if `RepurchaseTerm` is present, Tag 226.
1010    pub fn has_repurchase_term(&self) -> bool {
1011        self.message.body.has(tag::REPURCHASE_TERM)
1012    }
1013
1014
1015
1016
1017    /// Sets `SecurityDesc`, Tag 107.
1018    pub fn set_security_desc(&mut self, v: String) {
1019        self.message.body.set_field(tag::SECURITY_DESC, FIXString::from(v));
1020    }
1021
1022    /// Gets `SecurityDesc`, Tag 107.
1023    pub fn get_security_desc(&self) -> Result<String, MessageRejectErrorEnum> {
1024        let mut fld = field::SecurityDescField::new(String::new());
1025        self.message.body.get_field(tag::SECURITY_DESC, &mut fld.0)?;
1026        Ok(fld.value().to_string())
1027    }
1028
1029
1030    /// Returns true if `SecurityDesc` is present, Tag 107.
1031    pub fn has_security_desc(&self) -> bool {
1032        self.message.body.has(tag::SECURITY_DESC)
1033    }
1034
1035
1036
1037
1038    /// Sets `SecurityExchange`, Tag 207.
1039    pub fn set_security_exchange(&mut self, v: String) {
1040        self.message.body.set_field(tag::SECURITY_EXCHANGE, FIXString::from(v));
1041    }
1042
1043    /// Gets `SecurityExchange`, Tag 207.
1044    pub fn get_security_exchange(&self) -> Result<String, MessageRejectErrorEnum> {
1045        let mut fld = field::SecurityExchangeField::new(String::new());
1046        self.message.body.get_field(tag::SECURITY_EXCHANGE, &mut fld.0)?;
1047        Ok(fld.value().to_string())
1048    }
1049
1050
1051    /// Returns true if `SecurityExchange` is present, Tag 207.
1052    pub fn has_security_exchange(&self) -> bool {
1053        self.message.body.has(tag::SECURITY_EXCHANGE)
1054    }
1055
1056
1057
1058
1059    /// Sets `SecurityID`, Tag 48.
1060    pub fn set_security_id(&mut self, v: String) {
1061        self.message.body.set_field(tag::SECURITY_ID, FIXString::from(v));
1062    }
1063
1064    /// Gets `SecurityID`, Tag 48.
1065    pub fn get_security_id(&self) -> Result<String, MessageRejectErrorEnum> {
1066        let mut fld = field::SecurityIDField::new(String::new());
1067        self.message.body.get_field(tag::SECURITY_ID, &mut fld.0)?;
1068        Ok(fld.value().to_string())
1069    }
1070
1071
1072    /// Returns true if `SecurityID` is present, Tag 48.
1073    pub fn has_security_id(&self) -> bool {
1074        self.message.body.has(tag::SECURITY_ID)
1075    }
1076
1077
1078
1079
1080    /// Sets `SecurityIDSource`, Tag 22.
1081    pub fn set_security_id_source(&mut self, v: String) {
1082        self.message.body.set_field(tag::SECURITY_ID_SOURCE, FIXString::from(v));
1083    }
1084
1085    /// Gets `SecurityIDSource`, Tag 22.
1086    pub fn get_security_id_source(&self) -> Result<String, MessageRejectErrorEnum> {
1087        let mut fld = field::SecurityIDSourceField::new(String::new());
1088        self.message.body.get_field(tag::SECURITY_ID_SOURCE, &mut fld.0)?;
1089        Ok(fld.value().to_string())
1090    }
1091
1092
1093    /// Returns true if `SecurityIDSource` is present, Tag 22.
1094    pub fn has_security_id_source(&self) -> bool {
1095        self.message.body.has(tag::SECURITY_ID_SOURCE)
1096    }
1097
1098
1099
1100
1101    /// Sets `SecurityStatus`, Tag 965.
1102    pub fn set_security_status(&mut self, v: String) {
1103        self.message.body.set_field(tag::SECURITY_STATUS, FIXString::from(v));
1104    }
1105
1106    /// Gets `SecurityStatus`, Tag 965.
1107    pub fn get_security_status(&self) -> Result<String, MessageRejectErrorEnum> {
1108        let mut fld = field::SecurityStatusField::new(String::new());
1109        self.message.body.get_field(tag::SECURITY_STATUS, &mut fld.0)?;
1110        Ok(fld.value().to_string())
1111    }
1112
1113
1114    /// Returns true if `SecurityStatus` is present, Tag 965.
1115    pub fn has_security_status(&self) -> bool {
1116        self.message.body.has(tag::SECURITY_STATUS)
1117    }
1118
1119
1120
1121
1122    /// Sets `SecuritySubType`, Tag 762.
1123    pub fn set_security_sub_type(&mut self, v: String) {
1124        self.message.body.set_field(tag::SECURITY_SUB_TYPE, FIXString::from(v));
1125    }
1126
1127    /// Gets `SecuritySubType`, Tag 762.
1128    pub fn get_security_sub_type(&self) -> Result<String, MessageRejectErrorEnum> {
1129        let mut fld = field::SecuritySubTypeField::new(String::new());
1130        self.message.body.get_field(tag::SECURITY_SUB_TYPE, &mut fld.0)?;
1131        Ok(fld.value().to_string())
1132    }
1133
1134
1135    /// Returns true if `SecuritySubType` is present, Tag 762.
1136    pub fn has_security_sub_type(&self) -> bool {
1137        self.message.body.has(tag::SECURITY_SUB_TYPE)
1138    }
1139
1140
1141
1142
1143    /// Sets `SecurityType`, Tag 167.
1144    pub fn set_security_type(&mut self, v: String) {
1145        self.message.body.set_field(tag::SECURITY_TYPE, FIXString::from(v));
1146    }
1147
1148    /// Gets `SecurityType`, Tag 167.
1149    pub fn get_security_type(&self) -> Result<String, MessageRejectErrorEnum> {
1150        let mut fld = field::SecurityTypeField::new(String::new());
1151        self.message.body.get_field(tag::SECURITY_TYPE, &mut fld.0)?;
1152        Ok(fld.value().to_string())
1153    }
1154
1155
1156    /// Returns true if `SecurityType` is present, Tag 167.
1157    pub fn has_security_type(&self) -> bool {
1158        self.message.body.has(tag::SECURITY_TYPE)
1159    }
1160
1161
1162
1163
1164    /// Sets `SettleOnOpenFlag`, Tag 966.
1165    pub fn set_settle_on_open_flag(&mut self, v: String) {
1166        self.message.body.set_field(tag::SETTLE_ON_OPEN_FLAG, FIXString::from(v));
1167    }
1168
1169    /// Gets `SettleOnOpenFlag`, Tag 966.
1170    pub fn get_settle_on_open_flag(&self) -> Result<String, MessageRejectErrorEnum> {
1171        let mut fld = field::SettleOnOpenFlagField::new(String::new());
1172        self.message.body.get_field(tag::SETTLE_ON_OPEN_FLAG, &mut fld.0)?;
1173        Ok(fld.value().to_string())
1174    }
1175
1176
1177    /// Returns true if `SettleOnOpenFlag` is present, Tag 966.
1178    pub fn has_settle_on_open_flag(&self) -> bool {
1179        self.message.body.has(tag::SETTLE_ON_OPEN_FLAG)
1180    }
1181
1182
1183
1184
1185    /// Sets `StateOrProvinceOfIssue`, Tag 471.
1186    pub fn set_state_or_province_of_issue(&mut self, v: String) {
1187        self.message.body.set_field(tag::STATE_OR_PROVINCE_OF_ISSUE, FIXString::from(v));
1188    }
1189
1190    /// Gets `StateOrProvinceOfIssue`, Tag 471.
1191    pub fn get_state_or_province_of_issue(&self) -> Result<String, MessageRejectErrorEnum> {
1192        let mut fld = field::StateOrProvinceOfIssueField::new(String::new());
1193        self.message.body.get_field(tag::STATE_OR_PROVINCE_OF_ISSUE, &mut fld.0)?;
1194        Ok(fld.value().to_string())
1195    }
1196
1197
1198    /// Returns true if `StateOrProvinceOfIssue` is present, Tag 471.
1199    pub fn has_state_or_province_of_issue(&self) -> bool {
1200        self.message.body.has(tag::STATE_OR_PROVINCE_OF_ISSUE)
1201    }
1202
1203
1204
1205
1206    /// Sets `StrikeCurrency`, Tag 947.
1207    pub fn set_strike_currency(&mut self, v: String) {
1208        self.message.body.set_field(tag::STRIKE_CURRENCY, FIXString::from(v));
1209    }
1210
1211    /// Gets `StrikeCurrency`, Tag 947.
1212    pub fn get_strike_currency(&self) -> Result<String, MessageRejectErrorEnum> {
1213        let mut fld = field::StrikeCurrencyField::new(String::new());
1214        self.message.body.get_field(tag::STRIKE_CURRENCY, &mut fld.0)?;
1215        Ok(fld.value().to_string())
1216    }
1217
1218
1219    /// Returns true if `StrikeCurrency` is present, Tag 947.
1220    pub fn has_strike_currency(&self) -> bool {
1221        self.message.body.has(tag::STRIKE_CURRENCY)
1222    }
1223
1224
1225
1226
1227    /// Sets `StrikeMultiplier`, Tag 967.
1228    pub fn set_strike_multiplier(&mut self, val: Decimal, scale: i32) {
1229        self.message.body.set_field(tag::STRIKE_MULTIPLIER, fixer::fix_decimal::FIXDecimal { decimal: val, scale });
1230    }
1231
1232    /// Gets `StrikeMultiplier`, Tag 967.
1233    pub fn get_strike_multiplier(&self) -> Result<Decimal, MessageRejectErrorEnum> {
1234        let mut fld = field::StrikeMultiplierField::new(Decimal::ZERO, 0);
1235        self.message.body.get_field(tag::STRIKE_MULTIPLIER, &mut fld.0)?;
1236        Ok(fld.value())
1237    }
1238
1239
1240    /// Returns true if `StrikeMultiplier` is present, Tag 967.
1241    pub fn has_strike_multiplier(&self) -> bool {
1242        self.message.body.has(tag::STRIKE_MULTIPLIER)
1243    }
1244
1245
1246
1247
1248    /// Sets `StrikePrice`, Tag 202.
1249    pub fn set_strike_price(&mut self, val: Decimal, scale: i32) {
1250        self.message.body.set_field(tag::STRIKE_PRICE, fixer::fix_decimal::FIXDecimal { decimal: val, scale });
1251    }
1252
1253    /// Gets `StrikePrice`, Tag 202.
1254    pub fn get_strike_price(&self) -> Result<Decimal, MessageRejectErrorEnum> {
1255        let mut fld = field::StrikePriceField::new(Decimal::ZERO, 0);
1256        self.message.body.get_field(tag::STRIKE_PRICE, &mut fld.0)?;
1257        Ok(fld.value())
1258    }
1259
1260
1261    /// Returns true if `StrikePrice` is present, Tag 202.
1262    pub fn has_strike_price(&self) -> bool {
1263        self.message.body.has(tag::STRIKE_PRICE)
1264    }
1265
1266
1267
1268
1269    /// Sets `StrikeValue`, Tag 968.
1270    pub fn set_strike_value(&mut self, val: Decimal, scale: i32) {
1271        self.message.body.set_field(tag::STRIKE_VALUE, fixer::fix_decimal::FIXDecimal { decimal: val, scale });
1272    }
1273
1274    /// Gets `StrikeValue`, Tag 968.
1275    pub fn get_strike_value(&self) -> Result<Decimal, MessageRejectErrorEnum> {
1276        let mut fld = field::StrikeValueField::new(Decimal::ZERO, 0);
1277        self.message.body.get_field(tag::STRIKE_VALUE, &mut fld.0)?;
1278        Ok(fld.value())
1279    }
1280
1281
1282    /// Returns true if `StrikeValue` is present, Tag 968.
1283    pub fn has_strike_value(&self) -> bool {
1284        self.message.body.has(tag::STRIKE_VALUE)
1285    }
1286
1287
1288
1289
1290    /// Sets `Symbol`, Tag 55.
1291    pub fn set_symbol(&mut self, v: String) {
1292        self.message.body.set_field(tag::SYMBOL, FIXString::from(v));
1293    }
1294
1295    /// Gets `Symbol`, Tag 55.
1296    pub fn get_symbol(&self) -> Result<String, MessageRejectErrorEnum> {
1297        let mut fld = field::SymbolField::new(String::new());
1298        self.message.body.get_field(tag::SYMBOL, &mut fld.0)?;
1299        Ok(fld.value().to_string())
1300    }
1301
1302
1303    /// Returns true if `Symbol` is present, Tag 55.
1304    pub fn has_symbol(&self) -> bool {
1305        self.message.body.has(tag::SYMBOL)
1306    }
1307
1308
1309
1310
1311    /// Sets `SymbolSfx`, Tag 65.
1312    pub fn set_symbol_sfx(&mut self, v: String) {
1313        self.message.body.set_field(tag::SYMBOL_SFX, FIXString::from(v));
1314    }
1315
1316    /// Gets `SymbolSfx`, Tag 65.
1317    pub fn get_symbol_sfx(&self) -> Result<String, MessageRejectErrorEnum> {
1318        let mut fld = field::SymbolSfxField::new(String::new());
1319        self.message.body.get_field(tag::SYMBOL_SFX, &mut fld.0)?;
1320        Ok(fld.value().to_string())
1321    }
1322
1323
1324    /// Returns true if `SymbolSfx` is present, Tag 65.
1325    pub fn has_symbol_sfx(&self) -> bool {
1326        self.message.body.has(tag::SYMBOL_SFX)
1327    }
1328
1329
1330
1331
1332    /// Sets `Text`, Tag 58.
1333    pub fn set_text(&mut self, v: String) {
1334        self.message.body.set_field(tag::TEXT, FIXString::from(v));
1335    }
1336
1337    /// Gets `Text`, Tag 58.
1338    pub fn get_text(&self) -> Result<String, MessageRejectErrorEnum> {
1339        let mut fld = field::TextField::new(String::new());
1340        self.message.body.get_field(tag::TEXT, &mut fld.0)?;
1341        Ok(fld.value().to_string())
1342    }
1343
1344
1345    /// Returns true if `Text` is present, Tag 58.
1346    pub fn has_text(&self) -> bool {
1347        self.message.body.has(tag::TEXT)
1348    }
1349
1350
1351
1352
1353    /// Sets `TimeUnit`, Tag 997.
1354    pub fn set_time_unit(&mut self, v: String) {
1355        self.message.body.set_field(tag::TIME_UNIT, FIXString::from(v));
1356    }
1357
1358    /// Gets `TimeUnit`, Tag 997.
1359    pub fn get_time_unit(&self) -> Result<String, MessageRejectErrorEnum> {
1360        let mut fld = field::TimeUnitField::new(String::new());
1361        self.message.body.get_field(tag::TIME_UNIT, &mut fld.0)?;
1362        Ok(fld.value().to_string())
1363    }
1364
1365
1366    /// Returns true if `TimeUnit` is present, Tag 997.
1367    pub fn has_time_unit(&self) -> bool {
1368        self.message.body.has(tag::TIME_UNIT)
1369    }
1370
1371
1372
1373
1374    /// Sets `TransactTime`, Tag 60.
1375    pub fn set_transact_time(&mut self, v: Timestamp) {
1376        self.message.body.set_field(tag::TRANSACT_TIME, fixer::fix_utc_timestamp::FIXUTCTimestamp {
1377            time: v,
1378            precision: fixer::fix_utc_timestamp::TimestampPrecision::Millis,
1379        });
1380    }
1381
1382    /// Gets `TransactTime`, Tag 60.
1383    pub fn get_transact_time(&self) -> Result<Timestamp, MessageRejectErrorEnum> {
1384        let mut fld = field::TransactTimeField::new(Timestamp::UNIX_EPOCH);
1385        self.message.body.get_field(tag::TRANSACT_TIME, &mut fld.0)?;
1386        Ok(fld.value())
1387    }
1388
1389
1390    /// Returns true if `TransactTime` is present, Tag 60.
1391    pub fn has_transact_time(&self) -> bool {
1392        self.message.body.has(tag::TRANSACT_TIME)
1393    }
1394
1395
1396
1397
1398    /// Sets `UnitOfMeasure`, Tag 996.
1399    pub fn set_unit_of_measure(&mut self, v: String) {
1400        self.message.body.set_field(tag::UNIT_OF_MEASURE, FIXString::from(v));
1401    }
1402
1403    /// Gets `UnitOfMeasure`, Tag 996.
1404    pub fn get_unit_of_measure(&self) -> Result<String, MessageRejectErrorEnum> {
1405        let mut fld = field::UnitOfMeasureField::new(String::new());
1406        self.message.body.get_field(tag::UNIT_OF_MEASURE, &mut fld.0)?;
1407        Ok(fld.value().to_string())
1408    }
1409
1410
1411    /// Returns true if `UnitOfMeasure` is present, Tag 996.
1412    pub fn has_unit_of_measure(&self) -> bool {
1413        self.message.body.has(tag::UNIT_OF_MEASURE)
1414    }
1415
1416
1417}
1418
1419/// `RouteOut` is the callback type for routing `ContraryIntentionReport` messages.
1420pub type RouteOut = fn(msg: ContraryIntentionReport, session_id: SessionID) -> Result<(), MessageRejectErrorEnum>;
1421
1422/// Route type returned by the `route` function.
1423pub type Route = (&'static str, &'static str, Box<dyn Fn(&Message, SessionID) -> Result<(), MessageRejectErrorEnum> + Send>);
1424
1425/// Returns the begin string, message type, and route function for `ContraryIntentionReport`.
1426pub fn route(router: RouteOut) -> Route {
1427    let r = move |msg: &Message, session_id: SessionID| -> Result<(), MessageRejectErrorEnum> {
1428        router(ContraryIntentionReport::from_message(msg.clone()), session_id)
1429    };
1430    ("7", "BO", Box::new(r))
1431}