Re: newbie question about data I/O
On Sep 20, 11:58 am, "Ross A. Finlayson" <ross.finlay...@gmail.com>
wrote:
On Sep 20, 1:18 am, James Kanze <james.ka...@gmail.com> wrote:
On Sep 20, 8:24 am, "Ross A. Finlayson" <ross.finlay...@gmail.com>
wrote:
On Sep 19, 10:03 pm, Rune Allnor <all...@tele.ntnu.no> wrote:
On 19 Sep, 08:12, "Ross A. Finlayson" <ross.finlay...@gmail.com>
wrote:
while(!!input_file)
while(!!input_file)
while ( !!(in >> temp) vec.push_back(temp);
while(!!in)
Any reason for the consitent use of two exclamation marks?
Then it's on program read interrupt.
The read of the buffer ready, adjusting the buffer, is misread
on any file misread option. It is to help preserve exception
specification , on output read. Then, those could be
annotated, for reinsertion into the file handle clause for
file event blocks on the transactional signals. That's
importantly reverifiable where the file mapping blocks in the
parameter block work on override read vector with the
addressing along remodularization.
About the double negative, that's where exception handling on
the record helps momentize the object vector. So, if you
redefine it, emulating its process record, it's cheaper to
fill vectors off of the read record.
None of the above makes any sense to me, but one thing is
certain, most complers will generate exactly the same code with
or without the double exclamation. The double exclamation,
here, is basically a no-op, and has absolutely no effect on the
semantics of the program.
Maybe it helps if it's really short,that "!!input_file" means read,
REED.
No. !!input_file means "call the operator! function of
input_file, then complement the results". Without the !!, in a
conditional, "input_file" will be implicitely converted to bool,
and the results of implicitely converting it to bool are the
complement of the results of the operator! function. So all the
!! does is effectively complement the boolean value twice, which
is a no-op.
The usual idiom for reading a stream is:
while ( stream >> ... ) { /* ... */ }
or
stream >> ... ;
while ( stream ) {
/* ... */
stream >> ... ;
}
Anything else should only be used in exceptional cases.
--
James Kanze
Here's some more about how to make that useful.
I think you can alias the record generally, and then composite their
record definition on the input extraction. This is where the idea of
the file record has that while it is a file stream, it is an input
stream, so the input extractors would then want to reinstrument scan,
scanning forward, that has to do with scanner interlock. It's in
reading the record, to satisfy recognition of the record on the
initial memoizations. That is where the scanner code with table block
for the dump tables beyond code space fill with the types reinstrument
scan. What that means is that in the processing of the table record,
where it is a tabular record, in this choice of an input read
expression for the input iterator combined with loop body buildup,
where the result of the vector has linear random access, has to keep
all the edge cases that build up, in quadrature. Then squares and
circles.
What does it mean, alias the record? The record is the logical
definition, so it is the table's specification. The table has a
specification. It is stored in a file, the data. That is about
distance of memory in space and time, on the computer. It takes
longer to access data on the file than in the buffer, and the buffer
is a shared read area. Then, in the memory hierarchy from the atomic
step registers to the cache memory through it's squaring regions, in
layers, to RAM over flash block, they are messages in the small.
Useful, to start making this useful, an idea is to actually make a
library to functionalize this thing.
The STREAMS are a POSIX thing where the socket or file for signal flow
is occurring, the streams serialize the timestamp data. Then it's in
time codes, but really it's about ignoring streams and maintaining
composability with them, in the auto extraction.
Building auto extraction, might help with auto extraction accumulation
on the loop expression share pool for the pool jump into process
buffer.
With the processing of the input file, you want it to recontinue and
process the rest of the record, pointing back to the failed read
record. So it just maintains statistics on the return of the read
record. Then, those are naturally formed indices on the stack block
forward the stack record, with the stack accumulator in the share swap
process memory read record.
With the concrete time and space terms with the way Knuth could
combined the fixed accumulator rates of proven assembly language
machines, he uses a 256 code for the instruction number of so from the
instruction dictionary, of sorts, where that has hopefully a way to
build into it with instrinsics and maybe even auto replacements that
accumulate the composable and reversible or removable or quantumly
accumulated. Lots of assembly languages are that way, Fixed width
fixed size instruction list, with instruction counting. (Rise/fall.)
Really though, why would something like that be useful. Here's maybe
a help. There is lots of source code that uses files. Where is the
google tool to find source code uses of the pattern and show what
files conditions, those are read conditions, give the input to the
record storage. The use of the ::getline() function, for example, to
read the row record list header, has in the maintenance of the linear
forward address space of the random linear address, would maybe better
be "read_table_header()", then where for example XML containing table
records in an XML envelope in digital messaging, could have schema
verified the statement that is some tabular recognition, where then
the XML parser statistics would inform the parser instructions. That
is in a sense about defining that each of the set of instructions or
data files that were ever read have their instruction record either
read or not read. The "read_table_header()" function calls "::getline
()", that's what to compose so that after you take the header off, it
can be put back, with the spacing under the headers.
read_table_header(input_file);
while(!!input_file)
{
read(record);
}
Or, for example
read(input_file);
while(!!input_file)
{
input_file.record();
}
Yet, the code shouldn't be a non-templated thing if it could be made a
template about ifstream, particularly for example, say I/O controls on
register banks for control bank update. To templatize the algorithm,
is partially to separate the algorithm.
// specialize
typedef default
file_specification
enum file_specification_type_t
{
};
class file_name_forward_t = const char*;
typedef file_name_t file_name_forward_t;
static const filename_t filename_default = default;
vector_loop_serial_records(filename_t& filename)
try
{
ifstream input_file("filename"); // <- literal is convert=
ible
if (!!input_file);
// <- with !input_file or input_file.is_o=
pen(), read ready, off
constructor defaults, "input" fstream
// methods of istream are expected to be
// called on file stream, here mark templ=
ate boundary
// could also be input_file() when this "=
try" block has its types
collected.
{
try
}
while (!!inputfile) // <-
{
inputfile=
>> record; // <- the function to be composed to read the
records
}
catch (...)
{
}
catch(exception& e)
{
}
catch(exception e)
{
}
finally
{
}
}
}
catch(...) // <- wait to crunch the cancel on the transaction record
catch (exception e) // <- local exception? templatize
{
}
Then, the result of calling this function is that the row records of
the tabular data are in the random linear access vector, which gets
distributed in its loading into memory when it grows past word
boundaries, with memory barriers.
Is there a C++ collection base?
Here's another reason to use "!! input_file", "! ! input_file", it can
contain the exception handlers as well because for the template
generation there is the type, so that is the point about making it a
template with a typename in the template beyond just the class
definition. Different than "!! input_file()", maybe illegal. IT
could be a pointer or reference type, then, it could cast out of the
template with the template set chain handlers, to, then perhaps handle/
body, pointer to implementation?
template <class T>
template <typename T>
Then, maybe the typename is the file name, then the operators are
static and local, the input extraction operators, they're the
parameter block description.
Then the type transforms are serialized for simple maintenance or
maintainence of the pre-computed block with the input test validation.
Then, in the resource aquisition on the resulting data read, it's
forward error correcting, so the steps back up to the database
execution wait buffer , has the empty auto-constructors just off the
small scalar composite recomputes.
Idea is to snap back to scale on empty record adjustment.
Set the error handler with the fix for the record, that way the parser
restarts by signaling its own data path in the streams, on the
adjusted recompute or accompanying recompute on the record, just for
the maintainance of the timestamp banks, for forward statistical
postive error correction integrated
.
That is why maybe it's useful to maintain the template, and then make
the template for the file stream, with its name, where, this is where
the Original Poster, he is reading the file. Some else compiled the
data and stored it in the file. It's worth it for the reader to read
the file manually if that is convenient to do so.
Making the typename extension with the template cancelling on the
error-free cancellation of the template projections and extensions,
here maybe C++ does not have that in setting the exception handlers
for the function's stack autodefining on empty address offset the
object handle on the signal with the stream signal. This is about
making the call instead of
ifstream input_file ( "input.txt"); // <- what about input
filename_t input_identifier_type;
ifstream input_file(input_identifier_type); // <- input_file is an
input, here are the template extensions for input stream interface,
read.
template <class istream&, class filename_t> // <- reuse definitions
This should instead be with typename.
read_function(){
{
class istream reference; // <- use all the auto computed with the
const along reducing to signal catching
class filename type; // <- it's a class, you can use it in a template
to define automatic classes they are statically loaded.
filename::filename();
filename::
}
Then be sure not to define the read functions except for the compiler
has to generate more templates or else it would cancel, because:
there's not enough specification. Leave the input on the stack for
the local sidestep recompute in the reference vector, that goes in and
out of the process bank, with the unit step. The types that are
specialized when there isn't the input cancellation solve to re-
autodefine, because of simple maintenance of input record. Why is it
filename, it is the input indentifier, then the function is processed
in the run body, redefining run(), in anonymous run-body annotation
with the execution continuance. No, that is not how types can be used
in the forward definition of intrinsic references?
With read, that is part of bringing the data from getting the data
with again the template relaxation, with not cancelling compilation,
accomodating const re-reference, with path enumeration back up the
input record. Then, it would be nice if compilation then reflected on
the input data serialization and what happens is that it maintains
small diagrams which is then about using source code, that, you can
use later from source code.
That's just an example of the use of the reflective method body
compilation on the translation graph with the programming.
Then , say I want to write a program to convert a PDF generated from
TeX back to TeX source. Then, it's a good idea to automated the
generation of the transform. Take the PDF, and make it into the
correct TeX format. To submit my paper to arxiv, it's rejected
because it's a PDF file generated form TeX so I am supposed to submit
the original .TeX source code file, \TeX. I think I lost that data
but it might be on the disk image with the disk repartition. So, what
I wonder about are disk records with the copy of it.
On the input stack, add, check all the input parameters as a scalar
record, if they are the same input then return the static input
so, just there have an auto refinement stack that caches all the
record with the definition of all the equality satifiers over the
product space of the inputs, in that way, maintaining the chains of
function referred aliases with the permutation and transposition
generation. The indentical inputs cache the return value, but then
for that not just to be whatever it costs to execute the operation to
compare the input to the previous invocations', then it should
probably be written next, where this is about the development of the
execution stack in the automatic memory of the function prolog. If
that matches in the shift-matching, only actually matching a totally
identical input record to the previous output of the function, with
the content associative memory, that requires multiple copies of space
for the input record on the function's automatic local stack. Then,
if the functions is serializing the return values for the "NOT"
functions, abbreviated to the exclamation point !, bang, "!!!!!!",
NOT, then those functions return under the sharing with the input
parameter block stack for the catalog of the identical input vector.
Then in the loop, it is about where generally the record is row
identical because it's unique. Imagine reading the same file over and
over again, just adding to the same collection of records. Then the
records are accounts of the reads, there are some cases where, it is
not clear how to identify the local scalar offset with the
identification with the loop branch to record comparing to previous
instruction stream, in the matching along the input record.
Then, set the archive bit on the file, when it is computed that it
should be the same, given identical input subsets. Those are sampled
when the scanner snapshots for the archive bit on the file? Then
those could help represent dropouts on the file.
Still, that doesn't really show that it's useful, because the idea is
to have the parser on the istream, and then the file with it's
serialization to the physical recording medium has then more semantics
to handle like read and write cacheing and flushing and so on, and as
well then the raw reads and write with the disk API.
Read and writing the disk records should have another exception
catching block on the outside try for the I/O exception, then that is
also for socket I/O, because there are all kinds of exceptions to
consider on the transport layers. With the inner istream templates,
if they can autogenerate expected composable extracto tr functions,
then it is kind of like boost::spirit the use of overloading >> and <<
even more, making composable the specification that evaluates to the
input evaluator, statically there in the expression block.
Also there are other I/O events to consider.
Then the user is to combine the while block templatized. What that
means, is,
collection A, B, C;
input >> A >> B >> C; // <- this should be any order
Then the while block is encapsulated there. So on the first pass it
collects the istream that is imbued with the property of waiting to
run its input extractors over the collections' composed input
extractor. Within the template used with the convention, the types
add to the semantics of the input type, where it can be extended from
the in-place input type.
Then, the collection type has to have the operator >> for the
composable input extractor, that for expressivity has the semantics in
the convention to configure the function object to handle exceptions
on reading the input and input events.
istream& template <typename T> operator >> (istream& i, collection& c)
{
class istream_property
{
void* operator new (size_t void ); // this is just a pointer, but
it's automatic with the class
// where to write about the istream?
}
it would be static but not typesafe, the property. that is about
composing the extractors for the input.
// don't read i, just compose with the other collections to read the
data
// set a private variable in i, imbue the istream.
carry forward
return i;// because i is still the same just subclassed functionally
}
Then in templates the pre-composed input extractors have the idea
being that for each of the kinds of records there are, that they're
read from the file.
records
collection_type
collection
records += these;
input >> new_records;
compare (new_records, old_records);
old_records.compare(new_records);
collection_type c = new_records( templatized_type);
The istream's go to the extractor composers before there is ever
called istream read, which return a function object that is the while
loop with the error frame.
filename_t filename = "input.txt";
filespec_t filespec = "input.txt" + "input.dat" + "input.xml"; // <-
concatenate or combine the contents of these files
// <- also combine their extractor specifications?
filespec_t filespec += "schema.xsd" + record_line_delimited
(field_tab_delimited); // <- apply the write schema to the file spec
// then get the table representations for the data source/sink
template <typename reader_type>
{
// ifstream input_file(file_name) // <- file name, file des,
template <typename > class input : istream;
input in (filespec); // <- default an ifstream, file name, file des,
socket des
// here there is composed up the exception handlers for the I/O
events
template <typename > collection_type{
class T::collection;
class T::record;
class T::extractor : extractor_base, composable
}
}
// read(in);
in >> records >> out; // why is this extractor from the input to the
output, it could read to end or so, check the exception state of the
input
Then, it's not just records, it's transforming the records between
input and output. After reading records, there still could be unread
records. After writing the records to output, there still could be
unwritten records.
template <typename > operator >> (&input i,
Then, with covariant return types, the compiler picks up
input : istream& operator >> (istream& i, collection<record,
inputspec>);
Then writing
in >> records;
Then all the contents of the input, however they are composed from the
input specification, have had the input spec's extractors composed.
Then, they are combining with the records, the contents from the input
are the inputs to algorithms
Then, it's about the input type, exhausting the input, or waiting for
there to be more data in the input.
Now, the input extractors, should be the standard I/O stream
extractors, with the semantics, for reading and writing the literals.
Then, the point is getting the data into A, B, and C. Consider for
example XML with many different namespaces in the same file. These A,
B, and C collections of records
Yet, if the user wrote it
in >> records;
in >> records;
Basically it's a reference instead of a pointer, it's not clear how to
imbue the ifstream with a constructor from the input specification, so
the extractors can be generated using standard conventions for the
input extractors, in ease of use of overloading the input extractors.
Then, as to how to generate the file specifications, an example was
shown to compose them from literals like "filename.txt" and to
describe the specification of their content with the composable input
extractors.
input_specification spec =
{"filename.txt",record_line_delimited<field_tab_delimited> };
// <- here there are type converters for the literal array
input in(spec);
records<record_line_delimited<field_tab_delimited> > records; // <-
make records, overload records
// these are fixed column records
while(in) // <- here compose all the exception handlers, or imagine if
an event jumps to here
{
in >> records;
}
Hopefully the user could go like so
name n;
specification spec("filename.txt");
input in(spec);
records (Markers, locations, T, mu); // those parameters are of a type
that describe the contents, maybe just their names
in >> records;
Then, the records collection has what were the contents of the files
as records, row-tabular records, with fixed column widths. So, the
forward definitions to be implemented require a specification along
the lines of
tabular_data + row_major + row_record + record_line_delimited +
field_tab_delimited
Then, there is are questions about how to define the field types, how
to match them (eg string, int, double). There is the name of the
column, that's a name type, where there are considerations of names
about what names can be. Names are basically strings, with the notion
that names have a small maximum size, some MAX_NAME of a thousand
characters or so. Realistic name size expectations might be along the
lines of MAX_PATH, etcetera, the maximum length of a path
specification, for strings longer than that they are more the data
than the names.
Then, the input extractors are to work with the standard extractors
and fit within the standard extractor conventions.
ifstream ifs;
ifs >> records;
Then, also there is a consideration if the user might have written
ifs >> data;
// ifs.read(); // <- no, the read function of an input file stream
means something specific
read<ifstream>(ifs); // <- user might expect all of the input to be
read into the static data
and as well how the users have already written many input extractors.
I wonder how to make templates to then tie the extractors to the
record to then make that simply composable.
Then, for example in an input data file that is field tab delimited
within each record, where each item/record has an entry for each
field, the input extractor is to read it that way as well as reading
the contents. The user might want a function to which they could pass
other headers of the tables in the file data. Other generators of the
input might use spaces instead of tabs, this input has spaces and
tabs, defining the records on newlines. For code that uses its own
record types already, it would be nice to combine the extractors with
the records in their definition, for compositing the transforms, and,
to combine them in their default way which gets into, for example, in
terms of pointer ownership and serialization of object relationships,
regenerating local offsets.
That is about how the user might have a different form of input data
and expect it to be made coherent with data from a source with
different tables. That is about mapping the names of the tables in
transforms, with the record placement transforms. As well it is about
handling the composition of the extractions.
The template for compositing the extractors for the record can be
defined, how can it be defined automatically? That is about the
objects having the extractor from the input. The built-in types have
extractors defined with semantics. So, to later re-use them without
modifying user code then the idea is how to leave it say
while(in >> records); // <- empty process loop?
That the operation doesn't discard the input stream reference, instead
that it is instrumented in-place so that it compiles the templates
inline with user code.
Then, in normal user semantics, the object can be evaluated
automatically.
So, if the user has defined a record, then just bring it into the
template file with the templates to make the inserters, then the
inserters set themselves as the handlers in the standard input stream
extractor semantics.
c_file_has_structs.h:
union field // <- equalize / flatten alignment
{
word; // <- no union names, syntax error?
void*;
int;
char*; // <- C string, null-terminated
size_t; // <- specialize to size of buffer and C string
offset;
float;
};
struct RECORD
{
array<field> array; // <- objectize, make automatic
};
// <- records have fixed field width, computing record off field array
struct RECORD
{
};
Use the C semantics for structured storage of data, also read COBOL
records. Consider link table record type extraction.
Basically is C string pointer, and C data buffer pointer and data
buffer size pointer, with sharing the size pointer. Then, there are
the automatic types.
For that, build up the variadic template macro invocations. Here is a
way. It is about using alignment requirements on the struct, and the
guarantees of the sizeof operator on the typename. It gives the
alignment guarantees, the sizeof. It is used in the templates because
the numerics are evaluated before the templates. Generate then with
the templates the conversion of the struct type, by cancellations of
its alignment offsets, the extractor.
That is then about making it semantically equivalent to
RECORD r;
collection<RECORD> records;
input >> records;
input<RECORD>;
do { input }
||
do { !!input } // <- it's boolean but it checks the object
||
do { input() } // <- why try? in the templates, it's compiled
{
while input;
}
// no, maybe instead
if (input || input() || !!input )
{
input;
}
The point of writing that so many times is that each of those could be
different calls, or, each much the same or conditional on the others,
where before or after they are the same thing.
Then, there is maintain the automatic linearization of the program
components where there is the serialization of the compositor order
with the compositor components as those are the extraction operations
that work with the standard C++ library I/O stream istream extractor
semantics.
struct RECORD_WITH_C_STRINGS{
char* name;
char* record; // <- also these go in a union?
void* data;
size_t length; // <- this also hidden
unsigned ; // <- also
};
autocompose_input_extractor.hpp:
#include "template_pre_defs.hpp"
#include "c_file_has_structs.h"
#include "template_post_defs.hpp"
template <typename T> record;
// auto-local anonymous namespace
operator >> ( istream* in, char* a name is a sequence, consider how to
instrument in the enum ranges
Don't want to use a char* for the extractor operator, it's a C-
string.
So, for RECORD_WITH_C_STRINGS, the standard extractors that are
generated via templates from it
operator >> (istream& in, extractor_string& s)
or
operator >> (input& in, char* name) // these for extractors of names
(fields)
or
operator >> (input& in, record& record) // these for extractors of
records
where input extends istream and is the imbued istream interface that
is supposed to be generated from its own include files.
A problem with the second one is that then the char* character pointer
has its pointer ownership undefined. Templates can be defined to work
on the reference but then the template doesn't cancel to const.
record<RECORD> records;
file f("input.txt");
f >> records;
Then say you want to write the records, where you would then perhaps
expect to read them even again later.
file f("output.txt") save;
records >> save;
Or probably more normally
ostream out = ofstream("output.txt") out // <- templatize in function
out, anonymize identifier
records >> out;
Then, if more records were on the other size of the out, the template
compiler might have already generated the semantic overload.
template <typename ostream_type> operator >> (record<RECORD>& records,
ostream& out);
{
ostream_type this
// this template works on ostreams so it goes into templates that
work on ostreams
ostream out =
// auto-generated record inserters to the output stream
// if necessary, record the record specification that is part of the
specification that was used to construct the input reference.
// then, there is a consideration as to how to make concise and
readable combined specifications, with using comments, and compiler
erasure
// record all the changes in the semantic stream on the translation
for the records and parser support
// combine auto-generated to cancellation on the automatic record
redefines with the compiler unit base
records >> out;
}
Here is where, there are the standard semantics, and then there are
other program semantics that the existing inserters and extractors
already have defined, which is the point of using the standard
semantics with the standard C++ library.
So, the fields are built up to form the records from the C structs,
automatically. That is about a container class that is defined on
both sides of C language input in C++ non-compiling blocks under
program acceptance has the build up of the redefines to support the
automatic types.
Now, about categorizing the C++ input and output semantics, with the
standard streams, I was reading a book about the I/O stream semantics,
with for example setting the exception handlers, and being very
careful in handling the exception handlers to discover semantics
because the automatic generation of the inserters and extractors is
simply using alignment guarantees of the template evaluation of sizeof
with the fields in the struct. That is where there is a keyword in
the compiler to get the offsets of fields in a struct, for example
offset_of, that accepts ordinal inputs. So if I can use sizeof in
templates then I want to use offset of, but, not by the name/
identifier of the field of the struct, but by its natural layout
including for example unsigned layout. Then, inserters and extractors
can be worked out about other features of the structure type, for
automatically generating standard inserters and extractors from any C
struct that is plain old data, POD struct. Yet, the alignment size of
void* and char* is the same. This and other features have then more
definitions for the field type, because to generate the automatic
inserters and extractors for the I/O stream, if they are object
relations then to make them plain old data their entire relation of
object state is relativized to local coordinates with default to names
to give the objects small offsets in a cache line layout. So, with a
difference between, for example integer and floating point types where
those built-in types of the language could be in separate arithmetic
processing units including different clocks, the runtime's profile on
its alignment of those types can maintain object translation profiles
for writing the data inline from the maintained record.
Then, there is a consideration how to define records in terms of:
existing records in C/C++. Basically, it's an integer. So the types
of the data structures like the buffers with the extent or the string
with its extent have lots of semantics about the strings because
compared to binary data more often in the content prefixed buffers,
there is no reason to recount the length of the string in the record
when it is constant.
Yet, to indicate the intent of the programmer in making a thing about
the type that is the string type but also the mapping of the semantics
of the string type
Using the ostream semantics with the overloaded operator that way is
not the same as the const return of the reference
Then, here is a point about templates from before about generating the
templates even though they aren't valid, so when they're canceled,
they actually fit, for the automatic generation of the bridge
functions that on the translations input >> output the object
representations are maintained so it is actually a const reference to
the object state. The templates are interpreted but they aren't
generated until they're used, so, in the forward definitions, they are
for later definitions. That is just kind of pointless, looking for a
bug in the undefined behavior. Really it's probably reasonable to
figure that on the template evaluation maybe there could be the file
specification, where then defining a global general reference function
for only the auto generated compositors for the insertion and
extraction would then have the auto generated templates that exist
based upon the inherent semantics have the same expression
while (in)
{
class in_exception: io_exception;
try
{
in >> records;
}
catch (in_exception&)
{
}
};
Then, have the operation on the records, serially read the input files
and there have validators on all the inputs. The validator semantics
for the data types then are about the content layout. With the
tabular data, these are constant reads of records where every record
has a value for each field, so each record has an identical field
layout.
Also if the user writes
in >> records;
Then the programmer might want that to automatically express
template istream& operator >> (istream& in, auto& a)
{
// a is the return value type
a(in); // <- look, it's class constructor, or function object ()
operator()(auto& this); // <- is this here, cancel this with template
inline (); // <- run self
}
The templates generate the definition differently, then consider
canceling along how the construction initializers are generated.
Then, with the template expansion, it is about computing the field
offsets that match those of the struct. The use of the struct keyword
has some kind of serialization about a convention with looking around
for attributes that the function has it as a record with fields. So,
it's size alignments are to be translated simply. The specifications
are to be automatically generated with the hashes on the inputs. Use
principal component analysis on the inputs, then, use that to emit a
code for the state of the small space state. The specifications are
generated thus by linearizing the data. So, the name referencing is
on the fields with the name length vis-a-vis the input record length
with the above types. Also, the program simply maintains its file
access record in reusing the file, with access records on the file.
That's about then, treating the actual input file classes like structs
with using their sizeof and offsets of members in making from their
class definition these object auto-completion templates. That's
about, making a template namespace, then importing the standard C++
headers, and making fro them these templates by including their file
contents inline in the compilation unit of the C++ compiler, also with
the template features. Then, where it is attributed for the input
specification that the natural types to maintain symbolic reference
along the inputs and then there are advisement functions on the built-
in semantics of the type, to naturally serialize and reload the
staticly generated memos, then the memos can bank swap with the other
ones in the memory transactions around the memory barriers or memory
boundaries. They're static, so it is not convenient to realign the
stack for them to maintain more records than a small fixed amount of
records. Yet, if it is the same file name, for example, as an input
at the beginning of the program, came in as an istream for the
component library to read and write, if the memo compares the same
file name input and knows it's a constant input then it should use the
facility to check the input for constancy before reading it if the
dependent components would be unchanged when it's constant. Then, the
error or feedback or error handling has that the file has to be re-
read, or rather, that the difference must be known, the difference of
the states of the data that the files represent in terms of the
intrinsic semantics the guarantee of the related input data to all the
functions that depend on reading the file. Otherwise, if it just
knows a difference to the file, for example that it is just a line
appended to the end of the file at a given offset, then maybe lines
should be cache lines.
That brings up the utility of static result memoization for iterator
constancy along shared iterators. The compositors develop single
iterator pass components. The presence of the row vectors should tree
back to the records. What that means, is, the input record validators
on the localized object layout with the constancies on their
references maintain the satisfying input record identity. The idea
here is to build up from the file specification, as an example of the
input data, the memoized structures even for that file, where the
automatic types in the program advise that the program inputs are
interpreted. Then, where the automatic and supported types can
maintain the mutual satisfiability of their access then the results
don't need to be computed about vectorizing the input transform
instructions, so the compositor has total freedom to serialize input
from the collected I/O operations. Then, there is a consideration
about there being the empty handler on catching the io_exception
reference. If it's the empty handler, then, it just catches the
particular io_reference then in terms of the const referency of the
handling it tosses any other exception reference or non-io_reference
exception. Other exception handlers might expect that any function
between it and the handler would not do anything, but that's not
necessarily the same as having an empty block in the handler.
Now, there are the standard input extractors for the built-in types
including maybe pointers but the references are to be avoided. As
well, any object defined or templates-that-fit-the-templates extractor
is an automatic compositor.
Then, what seems worthwhile is to figure out how to present the
standard objects to the standard algorithms for template generation so
that then the automatic layout of the standard objects maintains in-
place efficient I/O reads of the data. That way, the istream that is C
++'s std::istream has a templatized subclass that is an input
abstraction so that when users of the standard I/O streams use the
default built-in I/O stream semantics
template <typename T> class input : T;
input<ifstream> in(input_file);
then has maybe the dual semantics for the first constructor variable
of the auto-layout type where the references have their extents
computed and const maintained so the input here is input_file, but the
input_file could also be the specification, generating converters to
constructor parameters, because in other cases the constructor of the
input template would better be initialized otherwise.
Excuse me, I digress from describing how maintaining the input
comparators is to work with the specification of the data in terms of
the fields and records thus that on constancy their processing results
are maintained, because the templates use the const reference paths
instead of non-const reference paths and then there is the idea of the
maintaining the const semantics in the non-const semantics.
Then, for the blocks, they could be in the const dependency chains
naturally, where, when a function-static access is in
operator >> (istream& in, data& d)
{
// maintain the const reference so to advise the caller that inputs
are idempotent
}
then
operator >> (const istream& in, data& d)
then consideration of
operator << (ostream& out, const data& d); // <- data is const or non-
const
operator << (ostream& out, data& d);
there are questions about how the compiler organizes references, but
actually that is probably defined behavior, about the priority of
selection of matching the function prototype for the function overload
by the parameter list, and as well warning on conventions.
Here, then I have introduced a data type, don't think a forward
definition. The data type here, now that is basically a collection of
records, but, it's also maybe to be compatible with the semantics of
raw pointers so that somehow it could define that it doesn't realias
pointers into the offsets of function objects, maybe exporting
function objects.
I hope that this doesn't seem an unreasonable course of consideration,
I wrote it today and I've read it several times.
Thanks,
Ross F.